## UG0608 User Guide BLDC Estimator v4.2 Power Matters.\* Microsemi Corporate Headquarters One Enterprise, Aliso Viejo, CA 92656 USA Within the USA: +1 (800) 713-4113 Outside the USA: +1 (949) 380-6100 Fax: +1 (949) 215-4996 Email: sales.support@microsemi.com www.microsemi.com © 2017 Microsemi Corporation. All rights reserved. Microsemi and the Microsemi logo are trademarks of Microsemi Corporation. All other trademarks and service marks are the property of their respective owners. Microsemi makes no warranty, representation, or guarantee regarding the information contained herein or the suitability of its products and services for any particular purpose, nor does Microsemi assume any liability whatsoever arising out of the application or use of any product or circuit. The products sold hereunder and any other products sold by Microsemi have been subject to limited testing and should not be used in conjunction with mission-critical equipment or applications. Any performance specifications are believed to be reliable but are not verified, and Buyer must conduct and complete all performance and other testing of the products, alone and together with, or installed in, any end-products. Buyer shall not rely on any data and performance specifications or parameters provided by Microsemi. It is the Buyer's responsibility to independently determine suitability of any products and to test and verify the same. The information provided by Microsemi hereunder is provided "as is, where is" and with all faults, and the entire risk associated with such information is entirely with the Buyer. Microsemi does not grant, explicitly or implicitly, to any party any patent rights, licenses, or any other IP rights, whether with regard to such information itself or anything described by such information. Information provided in this document is proprietary to Microsemi, and Microsemi reserves the right to make any changes to the information in this document or to any products and services at any time without notice. #### **About Microsemi** Microsemi Corporation (Nasdaq: MSCC) offers a comprehensive portfolio of semiconductor and system solutions for aerospace & defense, communications, data center and industrial markets. Products include high-performance and radiation-hardened analog mixed-signal integrated circuits, FPGAs, SoCs and ASICs; power management products; timing and synchronization devices and precise time solutions, setting the world's standard for time; voice processing devices; RF solutions; discrete components; enterprise storage and communication solutions, security technologies and scalable anti-tamper products; Ethernet solutions; Power-over-Ethernet ICs and midspans; as well as custom design capabilities and services. Microsemi is headquartered in Aliso Viejo, California, and has approximately 4,800 employees globally. Learn more at www.microsemi.com. # **Contents** | 1 | Revis | ion History | |---|--------|--------------------------| | | 1.1 | Revision 4.0 | | | 1.2 | Revision 3.0 | | | 1.3 | Revision 2.0 | | | 1.4 | Revision 1.0 | | | | | | 2 | Introd | uction 2 | | 3 | Hardv | vare Implementation | | | 3.1 | Inputs and Outputs | | | 3.2 | Configuration Parameters | | | 3.3 | Timing Diagram | | | 3.4 | Resource Utilization | # **Figures** | Figure 1 | Block Diagram of BLDC Estimator | 2 | |----------|----------------------------------------------|---| | | System-Level Block Diagram of BLDC Estimator | | | Figure 3 | Timing Diagram of the BLDC Estimator | 5 | # **Tables** | Table 1 | Input and Output Ports of the BLDC Estimator | |---------|-----------------------------------------------| | Table 2 | Configuration Parameter of the BLDC Estimator | | Table 3 | Resource Utilization of the BLDC Estimator | ### 1 Revision History The revision history describes the changes that were implemented in the document. The changes are listed by revision, starting with the current publication. #### 1.1 **Revision 4.0** The following is a summary of the changes made in revision 4.0 of this document. - Table 1, page 4 is updated to add a new signal name, clear\_buffer\_i and its description. - Figure 2, page 3, is edited to add the input signal name, clear\_buffer\_i. - Figure 3, page 5 is edited to show simultaneous generation of pulses for EALPHA\_FILTER\_START, EBETA\_FILTER\_START and EALPHA\_FILTER\_DONE, EBETA\_FILTER\_DONE pulses. #### **1.2** Revision **3.0** The following is a summary of the changes in revision 3.0 of this document. - Added the IP version to the document title. - Moved Configuration Parameter section in chapter 3, Hardware Implementation, page 3 to Configuration Parameters, page 5. #### **1.3** Revision 2.0 Updated for SAR 71202. #### 1.4 **Revision 1.0** Revision 1.0 was the first publication of this document. ### 2 Introduction The brush less DC (BLDC) estimator computes the rotor position based on motor parameters, voltage, and current values. The block also estimates motor speed. The algorithm is based on back-emf estimation and filtering. The motor parameters Rs, Ls, and sampling time Ts are used to build motor model. The voltages that are fed to the actual motor are fed to the motor model along with motor currents and are used to compute back-emf. A phase-locked loop (PLL) structure is used to find the angle of filtered back emf which is, aligned to rotor electrical position. Figure 1 • Block Diagram of BLDC Estimator The motor can accelerate or decelerate rapidly, in this case the rate of change of rotor position has to be dynamically and accurately tracked by the PLL. This is achieved by proper tuning of the PI controller that is part of the PLL. The PLL block uses the theta\_factor\_i input to scale the speed used in computing the rotor angle. This value is computed as: pll\_theta\_factor = $$\frac{67}{120} \times \frac{N_{rpm} \times N_{pp}}{f_{sw}}$$ where, $m N_{rpm}$ is rated motor speed in RPM $m N_{pp}$ is number of pole pairs $m f_{SW}$ is switching frequency # 3 Hardware Implementation This section describes the implementation details of the BLDC estimator. The following figure shows the system-level block diagram of the BLDC estimator. Figure 2 • System-Level Block Diagram of BLDC Estimator ## 3.1 Inputs and Outputs The following table lists the input and output ports of the BLDC estimator. Table 1 • Input and Output Ports of the BLDC Estimator | Signal Name | Туре | Description | |------------------------|--------|-------------------------------------------------------------------------------------------------------------------| | reset_i | Input | Active low synchronous reset signal | | sys_clk_i | Input | System clock | | start_i | Input | Start signal to start module computation - must be high for one system clock cycle | | clear_buffer_i | Input | When 1, internal speed filter buffer is cleared. When 0, buffer is normally operated. | | angle_pi_en_i | Input | Enable signal for PLL PI controller | | v_alpha_i | Input | Alpha axis voltage input for angle estimation | | v_beta_i | Input | Beta axis voltage input for angle estimation | | i_alpha_i | Input | Alpha axis current input for angle estimation | | i_beta_i | Input | Beta axis current input for angle estimation | | Ls_by_Ts_pu_i | Input | Motor Inductance L (in per unit) / sampling time | | Rs_pu_i | Input | Motor Resistance R (in per unit) | | ealpha_filter_factor_i | Input | Represents the Ealpha filter time constant – input as an exponent of 2 2^(ealpha_filter_factor_i) * sampling time | | ebeta_filter_factor_i | Input | Represents the Ebeta filter time constant – input as an exponent of 2 2^(ebeta_filter_factor_i) * sampling time | | pll_theta_factor_i | Input | Theta factor value | | angle_pi_kp_i | Input | Proportional constant for angle PI | | angle_pi_ki_i | Input | Integral constant for angle PI | | omega_filter_factor_i | Input | Represents the speed filter time constant – input as an exponent of 2 2^(omega_filter_factor_i) * sampling time | | done_o | Output | Indicates completion of speed computation. High for one clock cycle. | | theta_o | Output | Estimated angle (theta) output | | ealpha_o | Output | Back-emf on alpha axis | | ebeta_o | Output | Back-emf on beta axis | | ealpha_filtered_o | Output | Filtered back-emf on alpha axis | | ebeta_filtered_o | Output | Filtered back-emf on beta axis | | pll_pi_out_o | Output | Speed output from PLL | | speed_filtered_o | Output | Filtered speed output | | | | | ### 3.2 Configuration Parameters The following table shows the configuration parameter used in the hardware implementation of the BLDC estimator. This parameter is a generic and can be varied based on the application requirement. Table 2 • Configuration Parameter of the BLDC Estimator | Name | Description | |------------------|------------------------------------------------------------------------------------------| | g_NO_MCYCLE_PATH | Defines the number of clock delays required before asserting the multiplier done signal. | ### 3.3 Timing Diagram The following figure shows the timing diagram of the BLDC estimator. Figure 3 • Timing Diagram of the BLDC Estimator ### 3.4 Resource Utilization BLDC estimator is implemented on the SmartFusion<sup>®</sup>2 system-on-chip (SoC) field programmable gate array (FPGA), IGLOO<sup>®</sup>2 and RTG4<sup>™</sup> devices. The following table lists the resource utilization report after synthesis. Table 3 • Resource Utilization of the BLDC Estimator | Cell Usage | Description | |---------------------|-------------| | Sequential elements | 890 | | Combinational logic | 1450 | | MACC | 3 | | RAM1kx18 | 0 | | RAM64x18 | 0 |