7.5 Incremental Build Level 5
Assuming the previous build levels are verified successfully, this section verifies the position PI module and position loop with a QEP. When the motor is commanded to run, it is subjected to an initial alignment stage where the electrical angle and the QEP angle count are set to zero. After ensuring a stable alignment, the motor starts to run.
The implementation block diagram is given in Figure 30. The motor shafts must be kept disconnected to run these motors at different position settings simultaneously or only one motor can be tested at a given time.
- Open "dual_axis_servo_drive_settings.h" and select level 5 incremental build option by setting the BUILDLEVEL to FCL_LEVEL5 (#define BUILDLEVEL FCL_LEVEL5). The current loop regulator can be selected to be the PI controller or the complex controller by setting FCL_CNTLR to PI_CNTLR or CMPLX_CNTLR.
- Right-click on the project name, and then click Rebuild Project.
- When the build is complete, click the Debug button, reset the CPU, restart, enable real-time mode, and run.
- The software runs the motor through predefined motion profiles and position settings as set by the refPosGen() module. This module basically cycles the position reference through a set of values as defined in an array 'posArray[]'. These values represent the number of the rotations and turns with respect to the initial alignment position. Once a certain position value as defined in the array is reached, it pauses for a while before slewing toward the next position in the array. Therefore, these array values can be referred to as parking positions. During transition from one parking position to the next, the rate of transition (or speed) is set by 'motorVars[0].posSlewRate'. The number of positions in 'posArray[]' through which it passes before restarting from the first value is decided by 'ptrMax'. Hence, add the key variables 'posArray', 'ptrMax', and 'motorVars[0].posSlewRate' to the Expressions window as follows:
- motorVars[0].runMotor : flag to MOTOR_RUN or MOTOR_STOP
- motorVars[0].ptrFCL->lsw: the soft-switch flag that is auto promoted in a sequence inside the FCL.
- motorVars[0].posSlewRate: the rate of transition from one parking position to the next position.
- motorVars[0].pi_pos: the position PI controller structure variable.
- posArray: the position reference for dual motor.
- ptrMax: the maximum position sets.
- Set “enableFlag” to 1 in the expressions window. The variables named 'motorVars[0].isrTicker' and 'motorVars[1].isrTicker' are incrementally increased as shown in Expressions window to confirm the interrupts are working properly.
- Gradually increase voltage at DC power supply to get an appropriate DC-bus voltage.
- Set 'motorVars[0].runMotor' flag to MOTOR_RUN to run the motor, now the motor must be turning to follow the commanded position (see the following note if the motor does not turn properly).
- The parking positions in 'posArray[]' can be changed to different values to determine if the motor turns as many rotations as set.
- The number of parking positions 'ptrMax' can also be changed to set a rotation pattern.
- The position slew rate can be changed using 'motorVars[0].posSlewRate'. This rate represents the angle (in pu) per sampling instant.
- The proportional and integral gains of the speed and position PI controllers may be returned to get satisfactory responses. TI advises to first tune the speed loop and then the position loop.
- Set 'motorVars[0].runMotor' to MOTOR_STOP to stop the motor.
- Bring the system to a safe stop by reducing the bus voltage, taking the controller out of real-time mode, and resetting.
The same set of tests can be done on motor 2 by working with structure variable 'motorVars[1]'.
Figure 31 shows the position reference, and position feedback are plotted in the scope plot using DACs. They are aligned with negligible lag, which may be attributed to software. If the Kp and Ki gains of the position loop controller are not chosen properly, this may lead to oscillations in the feedback or a lagged response.
NOTE
- If the motor response is erratic, then the sense of turn of the motor shaft and the encoder may be opposite. Swap any two phase connections to the motor and repeat the test.
- The position control implemented here is based on an initial aligned electrical position (=0). If the motor has multiple pole pairs, then this alignment can leave the shaft in different mechanical positions depending on the prestart mechanical position of the rotor. If the mechanical position repeat ability or consistency is needed, then the QEP index pulse must be used to set a reference point. This may be taken as an exercise .