This is an Odrive 3.6, being used with an RW170 wheel, which has an AB encoder with no index.
Pasted below is the output for the latest issue. I can run full calibration, and run encoder offset calibration, and get no errors. Then I can switch to closed loop control and enter speed commands and the motor runs.
Then if I put it into idle and save, it comes back not working. If I put it into closed loop control mode I get an error and cannot command it to move.
In [361]: odrv0.axis0.requested_state = AXIS_STATE_FULL_CALIBRATION_SEQUENCE
In [362]: dump_errors(odrv0, True)
system: no error
(gives no error, removed to shorten)
In [363]: odrv0.axis0.motor.config.pre_calibrated
Out[363]: True
In [364]: odrv0.axis0.encoder.config.pre_calibrated
Out[364]: False
In [365]: odrv0.axis0.requested_state = AXIS_STATE_ENCODER_OFFSET_CALIBRATION
     ...: 
In [366]: dump_errors(odrv0, True)
system: no error
(gives no error, removed to shorten)
In [367]: odrv0.axis0.encoder.config.pre_calibrated
Out[367]: False
In [368]: odrv0.axis0.encoder.config.pre_calibrated = True
In [369]: odrv0.axis0.encoder.config.pre_calibrated
Out[369]: False
I cannot set pre-calibrated to true on the encoder
after a reboot, it won’t work, I get this error
axis0
  axis: no error
  motor: Error(s):
    MOTOR_ERROR_UNKNOWN_PHASE_ESTIMATE
I can run encoder calibration again and then the motor works
 odrv0.axis0.requested_state = AXIS_STATE_ENCODER_OFFSET_CALIBRATION
     ...: 
     ...: 
In [388]: dump_errors(odrv0, True)
(gives no error, removed to shorten)
In [389]: odrv0.axis0.controller.input_vel = 0.5
In [390]: odrv0.axis0.requested_state = AXIS_STATE_CLOSED_LOOP_CONTROL
In [391]: odrv0.axis0.controller.input_vel = 0.5
Is there some way to not need to run encoder calibration at startup? Or does it always need to do that if there is no index?
What does this MOTOR_ERROR_UNKNOWN_PHASE_ESTIMATE mean? I’ve checked the motor on another driver and it can run fine. The wiring is good, if I measure the resistance across phases it’s just the motor coil resistance, and besides it runs as expected once the encoder calibration has been run again.
I am going to be running this on a robot that can’t be manually calibrated every time it starts up. Do I need changes in the hardware or is there a setting to avoid needing to do this?
Alternatively, If it doesn’t have any way to automatically go into encoder driven FOC on startup, is there some way it could start sensorless, or on Hall sensors and automatically drop into encoder mode once it’s moved far enough?