ModalAI Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login
    1. Home
    2. shawn_ricardo
    3. Posts
    S
    • Profile
    • Following 0
    • Followers 0
    • Topics 6
    • Posts 27
    • Best 0
    • Controversial 0
    • Groups 0

    Posts made by shawn_ricardo

    • Physical placement of VOXL2 in quadcopter

      Hello,

      I'm looking to translate the physical VOXL2, from the cg of the drone, along the +X axis by about 15 centimeters.

      We see that PX4 has the option to specify this type of transform via EK2_IMU_POS_X,Y,Z parameters.

      For implementation, would we simply need to incorporate 1) the physical voxl2 translation
      2) the imu_px4 translation between voxl2 and imu_px4 (specified here)

      into EK2_IMU_POS_X? Are there any other transforms to include or some steps I've missed / not considered?

      Have y'all had experience in running such a setup, where the placement of the FC is not at the CG of the drone? I see that PX4 supports it, but I'm not sure how well it is actually performs.

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Unresponsive polling from FPV Racing 4-in-1 ESC

      @Alex-Kushleyev

      I raised the cmd-rate to 800 and noticed that curve sort of smooths out because the sample rate increased, which indirectly effects the plot granularity.

      raised_cmd_rate_ss.png

      At this point, the graph resembles that of the reference graph in documentation. Would you agree with this or recommend further tuning?

      Thanks!
      Shawn

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Unresponsive polling from FPV Racing 4-in-1 ESC

      @Alex-Kushleyev

      The voxl in perf mode didn't make a difference.

      Using the FTDI cable on a linux PC did make a difference, however. I was able to tune!

      Interestingly, calibration and power ramp test both track the plots referenced in the documentation. that is, continuous curves were obtained. These images are:

      calibration_ss.png

      rpm_spin_ss.png

      However, the power step test and RPM step tests deviate significantly from reference in that they are not continuous.

      I am running command provided from documentation, and obtain similar results for power/rpm

      • ./voxl-esc-spin-step.py --id 3 --power 20 --step-delay 1.5 --step-frequency 2 --timeout 3 --enable-plot 1 --cmd-rate 250 --step-amplitude 30

      • ./voxl-esc-spin-step.py --id 3 --rpm 2000 --step-delay 1.5 --step-frequency 1 --timeout 3.0 --enable-plot 1 --cmd-rate 250 --step-amplitude 2000

      rpm_power_spin_step_ss.png

      The XML file I am running is:

      <?xml version="1.0" encoding="UTF-8"?>
      
      <!-- Copyright (c) 2025 ModalAI Inc.
      
      Redistribution and use in source and binary forms, with or without
      modification, are permitted provided that the following conditions are met:
      
      1. Redistributions of source code must retain the above copyright notice,
         this list of conditions and the following disclaimer.
      
      2. Redistributions in binary form must reproduce the above copyright notice,
         this list of conditions and the following disclaimer in the documentation
         and/or other materials provided with the distribution.
      
      3. Neither the name of the copyright holder nor the names of its contributors
         may be used to endorse or promote products derived from this software
         without specific prior written permission.
      
      4. The Software is used solely in conjunction with devices provided by
         ModalAI Inc.
      
      THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
      AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
      IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
      ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
      LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
      CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
      SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
      INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
      CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
      ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
      POSSIBILITY OF SUCH DAMAGE.
      
      For a license to use on non-ModalAI hardware, please contact license@modalai.com -->
      
      <EscParameters>
      
        <IdParams>
          <param name="id"        value="127"/> <!-- ID assignment is fixed. Do not change -->
          <param name="dir"       value="2"/>   <!-- 0=fwd, 1=rev, 2=fwd id-based, 3=rev id-based -->
        </IdParams>
      
        <UartParams>
          <param name="protocol_version" value="2"/>          <!-- reserved for future use -->
          <param name="input_mode"       value="0"/>          <!-- reserved for future use -->
          <param name="baud_rate"        value="2000000"/>    <!-- communication bit rate -->
          <param name="char_timeout_ns"  value="0"/>          <!-- not used -->
          <param name="cmd_timeout_ns"   value="100000000"/>  <!-- timeout for incoming commands before ESC will stop the motor -->
        </UartParams>
      
        <TuneParams>
          <param name="pwm_frequency"       value="48000"/>  <!-- 24Khz is the only option for Tmotor board to reduce Mosfet switching losses -->
          <param name="vbat_nominal_mv"     value="22200"/>  <!-- used for sanity checking and limiting of voltage-dependent funcions -->
          <param name="num_cycles_per_rev"  value="14"/>     <!-- number of pole pairs in the motor. used for converting electrical frequency to mechanical rpm -->
          <param name="min_rpm"             value="583"/>    <!-- minimum RPM that will be attempted, otherwise capped -->
          <param name="max_rpm"             value="4667"/>   <!-- maximum RPM that will be attempted, otherwise capped -->
          <param name="min_pwm"             value="100"/>    <!-- cap for minimum power to be ever applied. max is 999 -->
          <param name="max_pwm"             value="999"/>    <!-- cap for maximum power to be ever applied. max is 999 -->
          <param name="pwm_vs_rpm_curve_a0" value="686.0452226861742"/>  <!-- this is actually motor_voltage vs rpm curve.. using legacy naming -->
          <param name="pwm_vs_rpm_curve_a1" value="2.853400603807748"/> <!--  -->
          <param name="pwm_vs_rpm_curve_a2" value="0.0003301049839666"/>
          <param name="kp"                  value="12"/>    <!-- 100... RPM controller proportional gain -->
          <param name="ki"                  value="2"/>    <!-- 10.. RPM controller proportional gain -->
          <param name="max_kpe"             value="30"/>    <!-- maximum proportional erorr term (max is 999) -->
          <param name="max_kie"             value="15"/>    <!-- maximum integral error term (max is 999) -->
          <param name="max_rpm_delta"       value="1200"/>    <!-- cap for maximum rpm error used in RPM controller -->
      
          <param name="spinup_type"         value="1"/>      <!-- 0: traditional, 1: sinusoidal . Sinusoidal is not yet implemented on this board-->
          <param name="spinup_power"        value="150"/>    <!-- power used to during spin-up procedure (out of 999)-->
          <param name="latch_power"         value="120"/>    <!-- power used during latching stage of spin-up (out of 999)-->
          <param name="spinup_power_ramp"   value="8"/>      <!-- it will take ( 4096 / (spinup_power_ramp*10000) ) seconds to ramp sinusoidal start-up power from 0 to spinup_power. Not yet implemented. -->
          <param name="spinup_rpm_target"   value="800"/>    <!-- Desired RPM at the end of the sinusoidal spin-up procedure. Not yet implemented. -->
          <param name="spinup_time_ms"      value="1000"/>   <!-- Duration of the sinusoidal spin-up procedure. Not yet implemented. -->
          <param name="spinup_bemf_comp"    value="1"/>      <!-- 0: disable, 1:enable back-emf compensation in sinusoidal spin-up procedure. -->
          <param name="motor_kv"            value="280"/>    <!-- kV value of the motor. used in back-emf compensation during spin-up. -->
      
          <param name="min_num_cross_for_closed_loop" value="90"/>  <!-- exit latching mode of fixed power after this number of zero crossings -->
          <param name="protection_stall_check_rpm" value="500"/>    <!-- if motor spins below this RPM, stall check will trigger and stop / restart the motor -->
      
          <param name="protection_current_soft_limit_a" value="0"/> <!-- over-current soft limit (will limit power to try to stay under the current limit). Only applicable to ESCs with individual current sensing -->
          <param name="protection_trip_current_a" value="0"/>       <!-- over-current hard limit (will stop the motor) after 100ms. Only applicable to ESCs with individual current sensing -->
      
          <param name="brake_to_stop"       value="0"/>             <!-- apply brake when stopping motor (or not) -->
          <param name="stall_timeout_ns"    value="20000000"/>      <!-- after spin-up, if no zero crossing is not detected for this amount of time, motor is considered stalled -->
          <param name="require_reset_if_stalled"      value="0"/>   <!-- require sending an array of zero commands to reset before next spin-up, if motor stalled -->
      
          <!--one beep-->
          <param name="tone_freqs"          value="[200, 200,240, 200, 0,0,0,0, 0,0,0,0]"/> <!-- 200 is 2000Hz, max 255 -->
          <param name="tone_durations"      value="[20,  0,  20,  0, 0,0,0,0, 0,0,0,0]"/> <!-- duration of each tone in units of 10 milli-seconds. Poor naming!!! -->
          <param name="tone_powers"         value="[50,  0,  50,  0, 0,0,0,0, 0,0,0,0]"/> <!-- max is 255 -->
      
      
          <param name="dt_threshold_ns"       value="150000"/>      <!-- during start up, ignore inter-commutation times less than this val, probably noise -->
          <param name="max_dt_ns"             value="2500000"/>     <!-- min and max values for time between two commutations. these are used as caps -->
          <param name="min_dt_ns"             value="50000"/>
          <param name="dt_bootstrap_ns"       value="2000000"/>     <!-- filter bootstrap value for commutation dt during start up -->
      
          <param name="spinup_stall_dt_ns"    value="6000000"/>     <!-- during spin-up, if no zero crossing is not detected for this amount of time, motor is considered stalled -->
          <param name="spinup_stall_check_ns" value="30000000"/>    <!-- time after beginning of spinup to start checking for spinup stall -->
      
          <param name="alignment_time_ns"     value="0"/>           <!-- alignment time before spin-up. not really needed -->
          <param name="timing_advance"        value="68"/>          <!-- positive value -> earlier commutation. helps avoid de-syncs if demag time is long. default: 60. absolute maximum is 90 -->
          <param name="sense_advance"         value="15"/>          <!-- positive value -> delayed zero crossing sensing. default: 20. absolute maximum is 45 (not recommended above 20)-->
      
          <param name="demag_timing"          value="1"/>           <!-- zero crossing timing tweak. default: 0. set to 1 for low kV (< 500kV) motors to reduce chance of de-sync. do not set to 1 if RPM can exceed 100K eRPM -->
        </TuneParams>
      </EscParameters>
      

      Would you be able to provide guidance on next tuning step?

      During the power step tests, the motor does not de-sync

      Thanks!
      Shawn

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Unresponsive polling from FPV Racing 4-in-1 ESC

      Hi @Alex-Kushleyev

      For the ramp test, the motor doesn't get stuck. I hear a smooth transition up to 95% power and the motor maintains that power for the timeout duration. Same for the calibration script. I hear the motor change speeds at the default duration of 0.5 seconds.

      Regarding the post's comment:
      "We calibrate from 10% - 95% per the instructions, but no matter the ESC/motor, the calibration process maxes out at around 60 - 70% power (11k - 13k RPM)."

      This happens because the loop in the script is tracking a variable that is set / updated only from within the script itself, rather than from esc.get_power(). When I updated the script to set the current power variable to the value returned by esc.get_power(), the loop actually goes to the max power specified. The downside here is that, given my current setup, although the command power seems to be accepted and implemented by the ESC, the returned value from esc.get_power() is not correctly reflected -- so the physical motor is spinning faster than the ESC is reporting and the loop continues to command the user defined MAX_POWER for a long time until the ESC catches up. I suppose one could update the loop to only increase commanded values once the returned value is verified, but for debugging purposes, the above is sufficient.

      I believe I did have the voxl in perf mode, but will try setting testing it again. As well as on a linux PC (i'll be using the same WSL as in the linked post, so maybe i could just try a container on the voxl with updated python)

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • Unresponsive polling from FPV Racing 4-in-1 ESC

      Hello,

      I'm calibrating the FPV Racing 4-in-1 ESC on the VOXL2 itself (not connected directly to the ESC via FTDI). When performing either the calibration (./voxl-esc-calibrate.py --id 2 --pwm-min 10 --pwm-max 95) or the power ramp test (./voxl-esc-spin.py --id 2 --power 100 --ramp-time 3.0 --timeout 5.0 --enable-plot 1 --cmd-rate 250), there are several instances were the y-values do not change for seconds

      The behavior is more readily seen in the power ramp test, since commanded values are continuous, whereas in the calibration test, a specific value is commanded for a given time period. Still, you can see in the calibration results that y value doesn't change any for far longer than the default step duration of 0.5 seconds

      Looking at the calibrate script, seems that the returned values from:

      • esc.get_current()
      • esc.get_power()
      • esc.get_rpm()
      • esc.get_voltage()
      • esc.get_temperature()

      are directly print to terminal, and not some other variable hanging around that maybe doesn't update.

      @Alex-Kushleyev has this behavior been seen? Any recommendations? It is difficult to tune commutation when values are not updated. The interesting pattern showing itself through repeated runs of the script is that the "duration unresponsiveness" increases as commanded power increases

      The following is output from voxl-esc scan:

      voxl2:/usr/share/modalai/voxl-esc-tools$ voxl-esc scan
      enabling bridge
      bridge enabled
      Detected Python version : 3.6.9 (default, Mar 10 2023, 16:46:00)
      [GCC 8.4.0]
      Found voxl-esc tools bin version: 1.9
      VOXL Platform: M0054
      Detected RB5 Flight, VOXL2 M0054 or M0104!
      INFO: Scanning for ESC firmware: /dev/slpi-uart-2, baud: 2000000
      Sending library name request: libslpi_qrb5165_io.so
      Sending initialization request
      INFO: ESC(s) detected on port: /dev/slpi-uart-2, baud rate: 2000000, protocol: firmware
      
      
      INFO: ESC Information:
      INFO: ---------------------
              ID         : 0
              Board      : version 42: ModalAi 4-in-1 ESC (M0138-1)
              UID        : 0x20373835464757130049002F
              Firmware   : version  39.20, hash 9c6233d6
              Bootloader : version    184, hash e1c038de
      
              ID         : 1
              Board      : version 42: ModalAi 4-in-1 ESC (M0138-1)
              UID        : 0x203738354647571300420025
              Firmware   : version  39.20, hash 9c6233d6
              Bootloader : version    184, hash e1c038de
      
              ID         : 2
              Board      : version 42: ModalAi 4-in-1 ESC (M0138-1)
              UID        : 0x20373835464757130049002A
              Firmware   : version  39.20, hash 9c6233d6
              Bootloader : version    184, hash e1c038de
      
              ID         : 3
              Board      : version 42: ModalAi 4-in-1 ESC (M0138-1)
              UID        : 0x20373835464757130042002A
              Firmware   : version  39.20, hash 9c6233d6
              Bootloader : version    184, hash e1c038de
      
      ---------------------
      successfully pinged ESCs
      disabling bridge
      Sending kill slpi command!
      bridge disabled
      

      I've also included the xml, calibration_results.html, and spin_results.html

      The motor is a Hobbyking CM X6 SE 280KV, a low KV motor.

      I am following the steps outlined in:

      • calibration.md
      • low_kv_motor_tuning.md
      • and guidance from this thread

      calibration_results.png
      spin_test.png

      Here is my XML

      <?xml version="1.0" encoding="UTF-8"?>
      
      <!-- Copyright (c) 2025 ModalAI Inc.
      
      Redistribution and use in source and binary forms, with or without
      modification, are permitted provided that the following conditions are met:
      
      1. Redistributions of source code must retain the above copyright notice,
         this list of conditions and the following disclaimer.
      
      2. Redistributions in binary form must reproduce the above copyright notice,
         this list of conditions and the following disclaimer in the documentation
         and/or other materials provided with the distribution.
      
      3. Neither the name of the copyright holder nor the names of its contributors
         may be used to endorse or promote products derived from this software
         without specific prior written permission.
      
      4. The Software is used solely in conjunction with devices provided by
         ModalAI Inc.
      
      THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
      AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
      IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
      ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
      LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
      CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
      SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
      INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
      CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
      ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
      POSSIBILITY OF SUCH DAMAGE.
      
      For a license to use on non-ModalAI hardware, please contact license@modalai.com -->
      
      <EscParameters>
      
        <IdParams>
          <param name="id"        value="127"/> <!-- ID assignment is fixed. Do not change -->
          <param name="dir"       value="2"/>   <!-- 0=fwd, 1=rev, 2=fwd id-based, 3=rev id-based -->
        </IdParams>
      
        <UartParams>
          <param name="protocol_version" value="2"/>          <!-- reserved for future use -->
          <param name="input_mode"       value="0"/>          <!-- reserved for future use -->
          <param name="baud_rate"        value="2000000"/>    <!-- communication bit rate -->
          <param name="char_timeout_ns"  value="0"/>          <!-- not used -->
          <param name="cmd_timeout_ns"   value="100000000"/>  <!-- timeout for incoming commands before ESC will stop the motor -->
        </UartParams>
      
        <TuneParams>
          <param name="pwm_frequency"       value="48000"/>  <!-- 24Khz is the only option for Tmotor board to reduce Mosfet switching losses -->
          <param name="vbat_nominal_mv"     value="22200"/>  <!-- used for sanity checking and limiting of voltage-dependent funcions -->
          <param name="num_cycles_per_rev"  value="14"/>     <!-- number of pole pairs in the motor. used for converting electrical frequency to mechanical rpm -->
          <param name="min_rpm"             value="577"/>    <!-- minimum RPM that will be attempted, otherwise capped -->
          <param name="max_rpm"             value="4626"/>   <!-- maximum RPM that will be attempted, otherwise capped -->
          <param name="min_pwm"             value="100"/>    <!-- cap for minimum power to be ever applied. max is 999 -->
          <param name="max_pwm"             value="999"/>    <!-- cap for maximum power to be ever applied. max is 999 -->
          <param name="pwm_vs_rpm_curve_a0" value="784.739381143"/>  <!-- this is actually motor_voltage vs rpm curve.. using legacy naming -->
          <param name="pwm_vs_rpm_curve_a1" value="2.77418758498"/> <!--  -->
          <param name="pwm_vs_rpm_curve_a2" value="0.000345512059078"/>
          <param name="kp"                  value="50"/>    <!-- 100... RPM controller proportional gain -->
          <param name="ki"                  value="10"/>    <!-- 10.. RPM controller proportional gain -->
          <param name="max_kpe"             value="100"/>    <!-- maximum proportional erorr term (max is 999) -->
          <param name="max_kie"             value="50"/>    <!-- maximum integral error term (max is 999) -->
          <param name="max_rpm_delta"       value="5000"/>    <!-- cap for maximum rpm error used in RPM controller -->
      
          <param name="spinup_type"         value="1"/>      <!-- 0: traditional, 1: sinusoidal . Sinusoidal is not yet implemented on this board-->
          <param name="spinup_power"        value="150"/>    <!-- power used to during spin-up procedure (out of 999)-->
          <param name="latch_power"         value="120"/>    <!-- power used during latching stage of spin-up (out of 999)-->
          <param name="spinup_power_ramp"   value="8"/>      <!-- it will take ( 4096 / (spinup_power_ramp*10000) ) seconds to ramp sinusoidal start-up power from 0 to spinup_power. Not yet implemented. -->
          <param name="spinup_rpm_target"   value="800"/>    <!-- Desired RPM at the end of the sinusoidal spin-up procedure. Not yet implemented. -->
          <param name="spinup_time_ms"      value="1000"/>   <!-- Duration of the sinusoidal spin-up procedure. Not yet implemented. -->
          <param name="spinup_bemf_comp"    value="1"/>      <!-- 0: disable, 1:enable back-emf compensation in sinusoidal spin-up procedure. -->
          <param name="motor_kv"            value="280"/>    <!-- kV value of the motor. used in back-emf compensation during spin-up. -->
      
          <param name="min_num_cross_for_closed_loop" value="50"/>  <!-- exit latching mode of fixed power after this number of zero crossings -->
          <param name="protection_stall_check_rpm" value="500"/>    <!-- if motor spins below this RPM, stall check will trigger and stop / restart the motor -->
      
          <param name="protection_current_soft_limit_a" value="0"/> <!-- over-current soft limit (will limit power to try to stay under the current limit). Only applicable to ESCs with individual current sensing -->
          <param name="protection_trip_current_a" value="0"/>       <!-- over-current hard limit (will stop the motor) after 100ms. Only applicable to ESCs with individual current sensing -->
      
          <param name="brake_to_stop"       value="0"/>             <!-- apply brake when stopping motor (or not) -->
          <param name="stall_timeout_ns"    value="20000000"/>      <!-- after spin-up, if no zero crossing is not detected for this amount of time, motor is considered stalled -->
          <param name="require_reset_if_stalled"      value="0"/>   <!-- require sending an array of zero commands to reset before next spin-up, if motor stalled -->
      
          <!--one beep-->
          <param name="tone_freqs"          value="[200, 200,240, 200, 0,0,0,0, 0,0,0,0]"/> <!-- 200 is 2000Hz, max 255 -->
          <param name="tone_durations"      value="[20,  0,  20,  0, 0,0,0,0, 0,0,0,0]"/> <!-- duration of each tone in units of 10 milli-seconds. Poor naming!!! -->
          <param name="tone_powers"         value="[50,  0,  50,  0, 0,0,0,0, 0,0,0,0]"/> <!-- max is 255 -->
      
      
          <param name="dt_threshold_ns"       value="150000"/>      <!-- during start up, ignore inter-commutation times less than this val, probably noise -->
          <param name="max_dt_ns"             value="2500000"/>     <!-- min and max values for time between two commutations. these are used as caps -->
          <param name="min_dt_ns"             value="50000"/>
          <param name="dt_bootstrap_ns"       value="2000000"/>     <!-- filter bootstrap value for commutation dt during start up -->
      
          <param name="spinup_stall_dt_ns"    value="6000000"/>     <!-- during spin-up, if no zero crossing is not detected for this amount of time, motor is considered stalled -->
          <param name="spinup_stall_check_ns" value="30000000"/>    <!-- time after beginning of spinup to start checking for spinup stall -->
      
          <param name="alignment_time_ns"     value="0"/>           <!-- alignment time before spin-up. not really needed -->
          <param name="timing_advance"        value="60"/>          <!-- positive value -> earlier commutation. helps avoid de-syncs if demag time is long. default: 60. absolute maximum is 90 -->
          <param name="sense_advance"         value="10"/>          <!-- positive value -> delayed zero crossing sensing. default: 20. absolute maximum is 45 (not recommended above 20)-->
      
          <param name="demag_timing"          value="1"/>           <!-- zero crossing timing tweak. default: 0. set to 1 for low kV (< 500kV) motors to reduce chance of de-sync. do not set to 1 if RPM can exceed 100K eRPM -->
        </TuneParams>
      </EscParameters>
      
      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: VOXL 2 Ethernet and USB Hub Add-on with Doodle lab radio

      Hi @AidanGallagher ,

      I'm using the same setup and had success with changes all instances of eth0 to eth1 under $MODEM == "doodle" under $PLATFORM == "qrb5165-rb5 in the script /usr/bin/voxl-modem-start

      It appears that when using the hub, the hub's build-in USB to ethernet chip always appears as eth0 (smsc75xx), even if nothing is plugged in

      The stock modem script at /usr/bin/voxl-modem-start hard-codes doodles static ip to eth0.

      under dmesg -w, when the dodole radio i plugged in (or just later on in the boot sequence), smsc95xx is assigned to eth1.

      as a result, the ip ends of being assigned to the wrong interface and the radio cannot pass traffic

      @Vinny , is there a better way to make these changes? something that won't get overwritten when a modal ai update occurs?

      posted in VOXL Accessories
      S
      shawn_ricardo
    • RE: Sensor Fusion Question w/ GPS, VIO, and downward distance sensor on Starling 2

      @Meytal-Lempel

      You still need vision input, so undo

      EKF2_EV_CTRL 15-->13 (remove external vision sensor aiding from vertical position calc)

      to ensure vision is aiding 3D position, yaw, and velocity. Then select range sensor as primary height input (EKF2_HGT_REF).

      for your purpose, you only want vision + range_finder as input sources into EKF (obv. you want to keep IMU data; no baro, no GPS). So ensure EKF parameters are turned on for only vision + range.

      Prior to flight, ensure the local_position supplied to PX4 from voxl qvio exists, that the position data makes sense (upon power on, should be 0s for xyzrpy on level ground), and that picking up the drone and moving around physically known distances (use a measuring tape or something) results in a corresponding update to /fmu/out/vehicle_local_position (I think that's the correct ROS2 topic) or instead of /fmu/out/vehicle_local_position, you can mavlink inspect local position

      For the Starling 2, since default params were vision only, my intent would be to turn on the range sensor and then update EKF2_HGT_REF to range. So maybe reset your parameters back to default Starling 2 params and make those adjustments?

      posted in GPS-denied Navigation (VIO)
      S
      shawn_ricardo
    • RE: Sensor Fusion Question w/ GPS, VIO, and downward distance sensor on Starling 2

      @Meytal-Lempel

      I haven't gotten around to this yet

      From what I recall, I think the range sensor is disabled. So, try to enable that sensor itself and verify via mavlink inspector that the range data is being received as expected.

      Then, once the range data exists, configure the EKF parameters to take as one of the sensor input sources the range values (what you've done above seems correct / along the correct direction).

      I think it would be okay to enable vision as an input sensor source, as well. But maybe not GPS + Vision, from what @Eric-Katzfey had mentioned.

      Or, you can allow for GPS input into EKF but make your GPS specific EKF parameters reject the GPS sensor input source outside of non-nominal conditions. By tuning the GPS EKF parameters to allow for only conditions that mimic strong GPS lock outside and reject GPS characteristics seen when inside (e.g., low GPS count).

      posted in GPS-denied Navigation (VIO)
      S
      shawn_ricardo
    • RE: Starling 2 Max with Ublox F9P Ultralight

      Just wanted to share: Using this approach, I was able to integrate CubePilot Here4

      posted in Starling & Starling 2
      S
      shawn_ricardo
    • RE: Sensor Fusion Question w/ GPS, VIO, and downward distance sensor on Starling 2

      @Eric-Katzfey

      Understood, will test parameter sets

      Thank you!

      posted in GPS-denied Navigation (VIO)
      S
      shawn_ricardo
    • RE: Sensor Fusion Question w/ GPS, VIO, and downward distance sensor on Starling 2

      Hi @Eric-Katzfey @Alex-Kushleyev , would y'all be able to answer the questions above?

      Just to recap, I ordered the Starling 2 and the default PX4 parameters shown via QGC have pretty much everything but vision sensor input turned off. As far as I know, the Starling 2 comes with a GPS (no mag) and downward facing distance sensor. Both could be used as sensor input sources into PX4s EKF. So, I'm curious if y'all use those sensors as input into your VIO implementation as a sort of upstream sensor fusion. In which case I can leave those PX4 parameters as is

      posted in GPS-denied Navigation (VIO)
      S
      shawn_ricardo
    • Sensor Fusion Question w/ GPS, VIO, and downward distance sensor on Starling 2

      Re: Running VIO with GPS active

      Hi @Cliff-Wong ,

      Following up on your reply in the post "Running VIO w/ GPS Active". I am flying a Starling 2 and have been unable to conclude how Modal handles various sensor input streams to PX4.

      I see that the Starling 2 has a downward distance sensor, VIO, and GPS (in addition to IMU). This is where the confusion begins because I also see that default Starling PX4 parameters only have Vision enabled for heading, velocity, and position via EKF, that GPS is disabled & set to not exist, and that downward lidar sensor input is disabled.

      Does the VOXL perform some sort of sensor fusion on these input sources, then send the output of fusion to PX4 through the vision topic such that vision encompasses GPS, downward distance sensor, and VIO? Or is it the case that the sensor streams other than VIO are actually ignored by PX4 and/or not sent by default (in which case I can simply enable the sensor input and update EKF parameters).

      Could you provide more clarity and maybe any recommendation on how I could leverage the sensors in PX4?

      posted in GPS-denied Navigation (VIO)
      S
      shawn_ricardo
    • RE: Integration of Hadron 640R w/ VOXL2 Flight Deck on Sentinel

      @Eric-Katzfey

      Would you be able to point me in the right direction? Maybe a list of technical docs or something of the sort?

      Thanks!

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Integration of Hadron 640R w/ VOXL2 Flight Deck on Sentinel

      Actually, can y'all provide the easiest path forward that supports just the tracking camera + hi-res front facing camera + FLIR Hadron?

      That setup would be ideal

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • Integration of Hadron 640R w/ VOXL2 Flight Deck on Sentinel

      Hello,

      On a separate VOXL2, I've got the FLIR Hadron 640R up and running using the hardware/instructions found in https://docs.modalai.com/voxl2-hadron/#flir-hadron-640r-support-on-voxl2-and-voxl2-mini

      I want to integrate this camera on the Modal AI Sentinel platform, but see that J7 is occupied by what appears to be the tracking camera and possibly a hi-res sensor.

      Currently, I don't require an occupancy grid, so its possible to disconnect both pairs of stereo-cameras on the Sentinel and free up those ports.

      Can y'all provide assistance in either:

      1. Disconnecting the stereo cameras (both hardware and software instructions) and configuring the hadron adapter on these newly available ports
      2. Disconnecting the stereo cameras (both hardware and software instructions), reconfiguring the existing tracking camera / hi-res camera on J7 to a newly freed port? (so I can connect the Hadron to J7)
      3. Some other method that you recommend?

      Thanks!

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Immediate crashes in HITL

      @Eric-Katzfey

      Okay, I'll keep this in mind as I develop toward offboard control. If I find any more information, I'll follow up here.

      Just a side note: I don't see this behavior in real-world flight during manual or position, seems to be isolated to HITL at this point in time.

      Thanks!

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Doodle Labs mini-OEM Helix Mesh Rider Radio M1-M6 Hex Band not configuring

      @Vinny

      Really appreciate the in-depth response and thoughtfulness, your intuition was correct 👏

      I tried to reproduce the setup from the windows PC

      1. Wall power supply to Starling 2
      2. (Same mains outlet) 12VAC to 5VDC to doodle labs radio
      3. Twisted D-/+ cables

      Upon USB connection, I'm able to see the following on dmesg -w:

      [ 1156.696173] usb 1-1: new high-speed USB device number 6 using xhci-hcd
      [ 1156.832876] usb 1-1: New USB device found, idVendor=0424, idProduct=9e00, bcdDevice= 3.00
      [ 1156.832886] usb 1-1: New USB device strings: Mfr=0, Product=0, SerialNumber=0
      [ 1156.848011] smsc95xx v1.0.6
      [ 1156.912009] smsc95xx 1-1:1.0 eth0: register 'smsc95xx' at usb-xhci-hcd.0.auto-1, smsc95xx USB 2.0 Ethernet, 00:30:1a:3a:eb:c8
      [ 1156.981572] IPv6: ADDRCONF(NETDEV_UP): eth0: link is not ready
      [ 1156.989474] QTI:Netlink Query to Kernel Success
      [ 1158.456775] IPv6: ADDRCONF(NETDEV_CHANGE): eth0: link becomes ready
      [ 1158.464411] QTI:LINK_UP message posted
      [ 1158.465167] QTI:Processing LINK_UP
      [ 1158.465606] smsc95xx 1-1:1.0 eth0: link up, 100Mbps, full-duplex, lpa 0x4DE1
      [ 1158.472660] QTI:Enable mobileap
      [ 1158.479629] QCMAP:Enable mobileap
      [ 1158.598399] QCMAP:Enable mobileap done
      [ 1158.602320] QTI:Setup TETHERED link
      [ 1158.676632] QTI:LINK_UP Processed
      

      and am able to stream data via voxl portal for a few seconds. Afterwards, the USB connection goes into a repeated disconnect/reconnect cycle.

      Moving forward for next testing (and obviously final configuration), I'll power both from the same source (w/ a BEC), shorten the cables, and be sure to twist the data lines (similar to mcbl-0085)

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Doodle Labs mini-OEM Helix Mesh Rider Radio M1-M6 Hex Band not configuring

      Hi @Eric-Katzfey , would you happen provide further assistance on this issue?

      My setup in summary:

      1. 120VAC to 5VDC 3.1A Type A Female adapter --> Type A male cable to 6 pin JST GH where 3 wires are spliced from the hot wire into pins 1/2/3 on port 4 and 3 wires are spliced from the ground into pins 4/5/6
      2. For connection to VOXL2, I have a JST GH 4 pin where pin1 is disconnected, pin 2 = D-, pin3 = D+, and pin4 = gnd. These connect to the corresponding wires for a USB 2.0 Type A Male to pigtails
      3. The USB Type A Male from (2) is plugged into the Starling 2 USB port (where the ALFA adapter usually is) and dmesg -w continues to show error -71
      4. The USB Type A Male from (2) is plugged into the USB adapter that comes with VOXL 2 USB3.0 / UART Expansion Adapter and dmesg -w continues to show -71
        • Not shown in the image (I have another separate VOXL2 board)

      Here is an image of the setup:
      bench_test.jpg

      This setup works repeatedly on Windows 11 PC. That is, the PC can ping the miniOEM doodle radio as well as a Wearable radio located several meters away.

      Any next steps would be great, thanks!

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Immediate crashes in HITL

      Hi @Eric-Katzfey ,

      I've tried those settings and the drone is able to stay hovering much long than expected. the positioning appears to be better, as well.

      What service(s) might be getting in the way of HITL performance?

      Also, I noticed during flight the drone vibrates significantly in HITL as soon as I publish offboard commands while in HOLD mode according to PX4's offboard guidelines. As soon as I stop publishing to /fmu/in/trajectory_setpoint, the vibrations stop. It is as if the drone is toggling between offboard and hold modes.

      I have "offboard_mode" set to "off" in /etc/modalai/voxl-vision-hub.conf. I am running my own ros2 offboard node. I've enabled voxl-cpu-monitor, voxl-microdds-agent, voxl-modem, and voxl-wait-for-fs. I am running the deb package of voxl_mpa_to_ros2 . The command I am running is ros2 run voxl_mpa_to_ros2 voxl_mpa_to_ros2_node

      I've tested the ability to publish offboard commands while in position hold mode in a completely separate px4 sim environment (just regular PX4 sim) and verified that drone position does not "vibrate" while offboard commands are being publishing and hold mode is the active mode.

      What could be the cause of this behavior issue?

      posted in Ask your questions right here!
      S
      shawn_ricardo
    • RE: Doodle Labs mini-OEM Helix Mesh Rider Radio M1-M6 Hex Band not configuring

      Per this post, I've tried the M0151 on another VOXL2 board w/ the USB to JST-GH cable. The doodle radio was still not showing up under lsusb

      @Moderator , do you have any additional insight into what may be occurring here?

      posted in Ask your questions right here!
      S
      shawn_ricardo