Note: The Guide can be downloaded in PDF format at the end of the article.
Disclaimer:
This quick startup guide is provided as a complementary resource to the official motor drive manual and datasheets. It is not intended to be the sole source of information for proper motor drive configuration and operation. Incorrect configuration or software bugs may cause unintended behavior, including uncontrolled motor operation or runaway. Users must always conduct tests cautiously and ensure they have a reliable method to safely stop the system in such scenarios. Roboteq, the author, and related parties are not liable for any hardware damage, personal injury, or other consequences arising from the use or misuse of the information in this guide.
Safety Symbols Explanation:
Table of Contents
1. How to Read This Guide
- This guide is part of a series of documents that must be followed sequentially to configure and test a BLDC motor. The process begins with the Open Loop configuration and continues through the sequence of documents until reaching the final target operating mode.
- The Open Loop mode guides are organized based on the sensors used (e.g., Hall, Hall & Encoder, Sin/Cos, etc.).
- For example, configuring a higher-level operating mode, such as Count Position with Hall sensors, requires completing the configuration and testing of lower-level modes, including Open Loop with Hall sensors, FOC Torque and FOC Speed.
2. Theory
Field Oriented Control
Below are some key points concerning the commutation of a Brushless DC (BLDC) motor:
- BLDC motors use permanent magnets in the rotor
- A three-phase voltage applied to the stator windings creates a rotating magnetic field that pulls the rotor and produces motion
- For SPM (Surface Permanent Magnet) motors, optimal torque is achieved when the stator’s magnetic field leads the rotor’s magnetic field by 90 electrical degrees. This is why BLDC motors typically require sensors to determine the rotor’s position and properly align the magnetic fields.
- Motor commutation is handled by a control algorithm called Field Oriented Control (FOC).
- The same sensor used to commute the motor can also be used for feedback
- Although the same sensor may be used, commutation and control are distinct functions managed by the motor drive.
Field Oriented Control (FOC) transforms the angle difference between the rotor and stator magnetic fields into two current vectors by applying Clarke and Park equations: Id (Flux amps) and Iq (Torque amps).
- These vectors allow direct control of the magnetic field angle by adjusting the Id and Iq currents
- Iq current is the component providing torque while Id controls the rotor flux
- In Open Loop mode (SPM motors), optimal torque is achieved by minimizing the Id current while Iq current results from the applied voltage command and the load.
- Id and Iq currents are regulated using two PI (Proportional-Integral) control loops
- The PI gains of these control loops are tuned based on the motor’s Resistance (R) and Inductance (L) parameters using the zero-pole cancellation method
- The RL parameters can be obtained from the motor datasheet or by using the motor characterization tool of the drive
- The user only needs to select the bandwidth of the FOC loop, which determines its responsiveness.
Commutation
Encoder: Max PPR vs Max RPM
- Roboteq drives use high-speed inputs to read encoder pulses, with a maximum frequency limit of approximately 200 KHz.
- The frequency of the encoder pulses is proportional to the motor speed and the sensor’s resolution.
- The maximum supported sensor resolution that can be used without exceeding the input's capacity is given by:
- Max_PPR= 60 x Max_Input_Frequency / Max_RPM
- The below figure illustrates the RPM/PPR curve with an input’s maximum frequency of 200 KHz, which is the case for most of the Roboteq RogoG4 models.
3. Hardware Connections
- Vmot is the connector for the voltage supplied to the motor and can operate within a range of 14 to 60 V.
- The Pwr Ctrl supply is optional and can be used to keep the drive operational in case of main battery disconnection. However, Pwr Ctrl must be connected to the battery’s negative terminal to allow the drive to shut down properly.
- The motor should be connected to the UVW power connectors.
HALL
In most motor drives the Hall sensors are connected to the dedicated Molex connector.
- The Hall sensor uses 3 wires for the A,B and C sensor signals and two wires for the Vcc and GND.
- The sensor is powered from the 5V output and the GND of the dedicated sensor connector.
- Hall sensors typically have open collector outputs, which are pulled up internally by the motor drive’s internal pull-up resistors. No additional circuitry is required to be added by the user.
ENCODER
- For BLDC drives, the encoder is commonly connected to the motor drive’s I/O connector.
- It uses 4 wires, two for the AB signals and 2 for powering (5V from the drive and GND).
- If the A/B signals are swapped, the sign of the measured speed will be inverted. However, this can also be corrected through the motor drive's configuration.
Supported Encoder output types
The motor drive supports Push-pull, TTL and Open-collector output encoders. While the first two types of sensors are directly supported, Open-collector output sensors require pull-up resistors from both the ENCA and ENCB inputs to 5 V in order to function properly.
To avoid reducing the signal below the MCU’s HIGH threshold, a pullup resistor of maximum 10Kohm should be used.
4. Required Parameters List
To complete the configuration sequence, ensure you have the following specifications readily available:
5. Configuration Steps
1. Configure Molex Input to "Hall Sensors"
SSI sensors and Hall sensors share the same Molex connector, so the sensor being used must be declared.
2. Configure the number of "Pole Pairs"
Pole pairs parameter is essential for the sinusoidal commutation and for the speed calculation. Pole pairs is the number of motor poles divided by 2.
3. Configure the switching mode to "Sinusoidal"
Both trapezoidal and sinusoidal commutation modes are supported by Roboteq drives. Sinusoidal mode results in quieter motor operation with reduced harmonics and current ripple, making it the preferred choice.
4. Set the Reference Seek Power to the rated current of the motor
The reference seek power is the current that will be provided to the motor during the motor/sensor calibration process.
5. Configure the Sinusoidal angle sensor to "Hall + Encoder"
This is the sensor that will be used for the commutation of the motor
6. Configure the Encoder Pulses/Rev
The PPR (Pulses Per Revolution) value can be found in the encoder datasheet. Ensure that the PPR is configured correctly, as it is a critical parameter for motor commutation. Also, configure the channel to which the encoder is connected. It is not necessary to set the encoder's function (e.g., Feedback) at this stage, but you may set it to "Feedback" if the encoder will also be used for Closed Loop operation.
7. Configure the FOC Flux and Torque gains
These are the gain values for the two PI controllers in the FOC loop, which regulate the torque and flux currents. The FOC gains can be set using the Motor Characterization tool.
The Motor Characterization tool offers two options:
1) Calculate the gains using the datasheet Parameters:
The datasheet parameters should list the phase-to-phase or the phase Resistance and Inductance values. If these parameters are given as phase-to-phase values, they should be divided by 2. Pay attention to the units, as the Tool accepts mOhm and uH.
The motor Resistance (R) and Inductance (I) values should be manually entered to the respective fields. The same inductance value should be entered to Ld and Lq parameters, if the motor is an SPM type.
2) Calculate the gains by characterizing the motor:
If the datasheet values are not available, the Roborun+ Utility offers the option to characterize the motor. The motor's resistance and inductance values are estimated by supplying a variable voltage to the motor. Be aware that the rotor will move during the characterization process, so it should not be blocked or loaded.
After setting the gains manually or through Motor Characterizations, you will be prompted to select a bandwidth for the FOC controllers.
The motor drive will calculate the FOC gains based on the following formulas:
Prefer a moderate bandwidth value, as high values may cause vibrations, while low values will result in a slower current response.
After closing the tool, the FOC parameters are updated. To view the changes in the utility, click Load from Controller.
8. Configure the Amps Limit parameter
The drive regulates the motor current based on three configurations: the Amps Limits Parameter, the I²T Protection setting, and the Maximum Motor Output Power. Each of these defines a maximum allowed current, and the drive will restrict the current to the lowest of the three values.
8.1 Set the motor Amps Limit Parameter: The drive will prevent the motor current from exceeding this value by reducing the motor voltage. The amp limit value should be set equal to the peak current of the motor.
8.2 Optionally set the Amps Trigger Action and Amps Trigger Delay parameters: Since the peak current of a motor is typically only allowed for a short duration, Roboteq drives offer the option to trigger an action if the motor current exceeds a specified value for a specific amount of time. This can be configured using the Amps Trigger Action and Amps Trigger Delay parameter.
8.3 Enable the I2T protection: I2T protection is a method that measures the energy supplied to the motor in order to protect it from overheating. It works by integrating the excessive current supplied to the motor and comparing it with a threshold value. If the accumulator exceeds the I2T threshold, the drive will start limiting the current at 80% of the nominal current, allowing the motor to cool down and causing the I²T accumulator to decrease accordingly.
To enable the protection, configure the I2T Time, which is the time that the motor can handle its maximum current, and Nominal Current, which is the nominal current of the motor.
8.4 Set the Maximum Motor Output Power parameter: Similar to the Amps Limits parameter, the Maximum Motor Output Power parameter restricts current to prevent the motor's power from exceeding the configured value. Set this parameter according to the motor datasheet by calculating the product of the motor's maximum rotational speed (in rad/s) and peak torque.
9. Configure the operating mode to "Open Loop"
Even if the final target is to use Close Loop Speed or Position mode, it is mandatory to first test the motor in Open Loop.
10. Disable the Sensor Error Detection on the unused channel
In dual-channel controllers, if one of the two sensors is not connected, the Sensor Error will be triggered. Disable the Sensor Error Detection in the unused channels
11. Go to Diagnostics Tab and run Motor/Sensor Setup
Motor/Sensor setup is the process where the controller will record the locations of the Hall sensors in positive and negative directions. This is required for the Sinusoidal commutation of the motor. During the calibration, the motor will move for some degrees in both directions.
In the chart enable the Motor amps and Hall Status parameters and ensure the following:
- Hall status Min and max is 1 and 6
- Hall status takes all the intermediate values including 1 and 6
- Hall status 7 and 0 which would indicate a sensor fault value are not present
- The Motor Amps are equal to the Reference seek power
When the motor/sensor setup finish it will print the Hall Sensor Angle Table (HSAT).
- Ensure that the HSAT contains no repeated values and does not include a value of 64. Either observation would indicate a sensor fault.
- Ensure that by repeating the process you get similar values
12. Go to the Run Tab and Evaluate the Open Loop response without load
On the Chart enable the below parameters.
13. Give a motor command using the slider and verify the following:
- Run the motor in both directions. Verify that the Motor Amps value is below or equal to the “no load current” of the motor, when the given command is constant. The motor current can increase during acceleration/deceleration but at constant power, the motor amps should be relatively low. The motor’s no load current should typically be below 3 A, however the value may vary depending on the motor’s size and gearbox ratio.
- Supply a full command in both directions. Verify that the Motor Amps in both clockwise (CW) and counterclockwise (CCW) directions are symmetrical. If the current differs significantly (by more than 1 A), then something in the configuration might not be correct.
- Verify that the motor Flux Amps variable exhibits a small fluctuation and stabilizes quickly to zero during motor acceleration and deceleration.
- Verify that the FOC angle correction variable is stable or that it stabilizes quickly when changing the motor speed.
- Verify that the Internal Sensor Speed RPM is stable when supplying a constant command
- Verify that the Internal Sensor Speed RPM is symmetrical when supplying full command in both directions. Depending on the motor, an error up to 5% can be acceptable, but higher variation may indicate a tunning or sensor issue.
- Verify that the Internal Sensor Speed RPM and Encoder Speed RPM have similar values in all cases. If the Encoder RPM and Internal RPM differ, it may indicate that some parameters are not configured properly.
- Verify that the Internal Sensor Speed RPM is reported as positive by giving a positive motor command. If not, invert the pole pairs sign, to fix it (e.g., -5 from 5).
- Verify that the Encoder Speed RPM is reported as positive by giving a positive motor command. If not, invert the PPR parameter sign to fix it (e.g., -4096 from 4096)
It is crucial having the encoder and Hall (internal sensor) speed reported with the correct sign otherwise the motor can go into a runaway condition when configuring the Closed Loop modes.
If all the steps have been passed, then the Open Loop configuration is effective, and the motor is ready to be configured in any of the supported Closed Loop operating modes!
6. Troubleshooting
A troubleshooting table with some common Problems and solutions follows:
One common reason for a motor's inability to rotate is a failure on either the sensor or motor drive side. To troubleshoot, you can use the motor drive's diagnostic tab to review the Hall sensor signals and identify any issues:
- During motor/sensor setup, check if the hall signal has the correct pattern. The Hall status should take all the states from 1 to 6. States 0 or 7 are invalid and indicate a sensor error (missing signal or sensor misalignment)
During motor and sensor setup, ensure that all Hall states have the same duration. If the sensor is misaligned, as shown in this example, the commutation will be compromised. This can cause the motor to draw high and unstable current, leading to noisy performance, even if it manages to rotate.
If a signal is missing on the diagnostics tab chart, check if all signals are present at the sensor’s output. To achieve this, connect the sensor to the drive's input as the pull-up resistors that are integrated internally are required. Then, manually rotate the shaft, and use a multimeter to verify that all signals are present. Their state should change from 0 to 5V. If all signals are present but the drive is unable to read any of them, the drive’s input may be damaged.
To troubleshoot Encoder related issued do the following:
Probe both encoder channels and ensure:
- When rotor is rotating, both channels are present
- Signal Amplitude is higher than 3.8V
- The phase difference of the signal is 90 degrees
7. Configuration Example