#include "ClearCore.h"
#define motor ConnectorM0
#define TRIGGER_PULSE_TIME 25
#define INPUT_A_B_FILTER 20
#define POSITION_INCREMENT_1 1000 // Input A "off" setup selection, 1000 counts (CCW)
#define POSITION_INCREMENT_2 -1000 // Input A "on" setup selection, -1000 counts (CW)
#define HomingSensor ConnectorDI6
#define baudRate 9600
#define SerialPort ConnectorUsb
#define HANDLE_MOTOR_FAULTS (0)
void HomingSensorCallback();
bool MoveIncrements(uint32_t numberOfIncrements, int32_t positionIncrement);
void HandleMotorFaults();
int main() {
Connector::CPM_MODE_A_DIRECT_B_DIRECT);
motor.HlfbMode(MotorDriver::HLFB_MODE_HAS_BIPOLAR_PWM);
motor.HlfbCarrier(MotorDriver::HLFB_CARRIER_482_HZ);
motor.MotorInAState(false);
motor.MotorInBState(false);
HomingSensor.Mode(Connector::INPUT_DIGITAL);
HomingSensor.InterruptHandlerSet(HomingSensorCallback, InputManager::CHANGE);
motor.MotorInBState(HomingSensor.State());
SerialPort.Mode(Connector::USB_CDC);
SerialPort.Speed(baudRate);
uint32_t timeout = 5000;
SerialPort.PortOpen();
while (!SerialPort &&
Milliseconds() - startTime < timeout) {
continue;
}
motor.EnableRequest(true);
SerialPort.SendLine("Motor Enabled");
SerialPort.SendLine("Waiting for HLFB...");
while (motor.HlfbState() != MotorDriver::HLFB_ASSERTED &&
!motor.StatusReg().bit.MotorInFault) {
continue;
}
if (motor.StatusReg().bit.MotorInFault) {
SerialPort.SendLine("Motor fault detected.");
if(HANDLE_MOTOR_FAULTS){
HandleMotorFaults();
} else {
SerialPort.SendLine("Enable automatic fault handling by setting HANDLE_MOTOR_FAULTS to 1.");
}
SerialPort.SendLine("Enabling may not have completed as expected. Proceed with caution.");
SerialPort.SendLine();
} else {
SerialPort.SendLine("Motor Ready");
}
while (true) {
MoveIncrements(1, POSITION_INCREMENT_1);
MoveIncrements(1, POSITION_INCREMENT_2);
MoveIncrements(4, POSITION_INCREMENT_1);
MoveIncrements(4, POSITION_INCREMENT_2);
}
}
bool MoveIncrements(uint32_t numberOfIncrements, int32_t positionIncrement) {
if (motor.StatusReg().bit.MotorInFault) {
if(HANDLE_MOTOR_FAULTS){
SerialPort.SendLine("Motor fault detected. Move canceled.");
HandleMotorFaults();
} else {
SerialPort.SendLine("Motor fault detected. Move canceled. Enable automatic fault handling by setting HANDLE_MOTOR_FAULTS to 1.");
}
return false;
}
SerialPort.Send("Moving ");
SerialPort.Send(numberOfIncrements);
SerialPort.Send(" * ");
switch (positionIncrement) {
case POSITION_INCREMENT_1:
SerialPort.SendLine(POSITION_INCREMENT_1);
motor.MotorInAState(false);
break;
case POSITION_INCREMENT_2:
SerialPort.SendLine(POSITION_INCREMENT_2);
motor.MotorInAState(true);
break;
default:
return false;
}
motor.EnableTriggerPulse(numberOfIncrements, TRIGGER_PULSE_TIME, true);
SerialPort.SendLine("Moving.. Waiting for HLFB");
while (motor.HlfbState() != MotorDriver::HLFB_ASSERTED &&
!motor.StatusReg().bit.MotorInFault) {
continue;
}
if (motor.StatusReg().bit.MotorInFault) {
SerialPort.SendLine("Motor fault detected.");
if(HANDLE_MOTOR_FAULTS){
HandleMotorFaults();
} else {
SerialPort.SendLine("Enable automatic fault handling by setting HANDLE_MOTOR_FAULTS to 1.");
}
SerialPort.SendLine("Motion may not have completed as expected. Proceed with caution.");
SerialPort.SendLine();
return false;
} else {
SerialPort.SendLine("Move Done");
return true;
}
SerialPort.SendLine("Move Done");
return true;
}
void HomingSensorCallback() {
motor.MotorInBState(HomingSensor.State());
}
void HandleMotorFaults(){
SerialPort.SendLine("Handling fault: clearing faults by cycling enable signal to motor.");
motor.EnableRequest(false);
motor.EnableRequest(true);
}