1. Introduction
The use of permanent magnets (PMs) in electric machines has several advantages over conventional machines, such as the absence of field winding losses, simpler construction, greater efficiency, and higher torque density [
1,
2]. Additionally, considerable improvements in dynamic performance can be achieved because there is a nearly constant air-gap magnetic flux density in each permanent magnet pole face. Brushless direct current (BLDC) motors use PMs as magnetic field excitation and are widely popular in automotive, aeronautic, industrial, and commercial applications because of reduced mechanical losses, lower maintenance costs and higher reliability compared to brushed motors.
The BLDC motor analyzed in this work has a trapezoidal back-emf waveform, and it is fed by a DC power source through a three-phase power converter. Several strategies have been reported in the literature for the control of BLDC motors such as PID, fuzzy logic, neural networks, optimization via genetic algorithms, and sliding-modes [
2,
3,
4,
5,
6]. Depending on the application, control schemes may be designed for regulation or tracking of rotor position, speed or torque.
The performance of typical control schemes for BLDC motors relies on information of rotor position and machine parameters. The rotor position is determined via Hall-effect sensors or sensorless techniques, whereas the parameters must be known a priori or determined online [
3,
7]. These parameters are the winding resistance and inductance, rotor inertia, back-emf constant, and the coefficients of damping or friction [
8,
9].
Accurate information of parameters is generally not available, and an identification scheme must be formulated. There are several ways to determine motor parameters. However, an accurate estimation is subject to precise design information of the machine such as stator and rotor cores materials as well as their geometry, type of permanent magnets and winding distribution, etc. When this information is available, there are popular methods for determining these parameters such as the classical models of magnetic circuits or finite element analysis (FEA) [
10,
11,
12].
Detailed information on machine design is generally not available. Therefore, experimental tests are usually performed to obtain the parameters listed above [
13]. In [
9,
14,
15,
16], stator resistance and inductance, rotor inertia and damping coefficient of a DC motor are determined by analyzing its step response to blocked-rotor and no-load tests. In [
17], a modified blocked-rotor test is performed to determine the direct and quadrature axes inductances and the back-emf constant of a PM synchronous motor. In [
4], the motor is excited with a variable frequency input and the frequency response is fitted to appropriate transfer functions, resulting in the lumped parameters of the model. The main drawback of these tests is that they are performed under very specific circumstances—blocked rotor, zero speed, no load, simplified dynamics—which may not represent the performance of the motor under normal operating conditions. Therefore, the results may need to be refined.
The electrical and mechanical parameters are also subject to variation due to different causes; for example, stator resistance, damping coefficient and PM strength vary with temperature, while inductances vary nonlinearly with the effective air-gap field and damping coefficient varies with rotor speed. These variations are compensated using online identification schemes based on optimization methods and adaptive controllers [
3,
15,
18]. In [
18], a method that combines a genetic algorithm and simplex search is used to determine the parameters of the nonlinear friction components in a DC motor. In [
3], an algebraic identification method combined with a classical gradient search are used online on a BLDC motor to tune an adaptive speed controller; the model used is a simplified one that neglects the damping coefficient. The results are satisfactory in numerical simulation; however, no experimental validation is provided. In [
19], the moment of inertia is estimated dynamically using a state observer to improve the performance of a PI control scheme.
Intelligent strategies such as artificial neural networks, particle swarm and bat algorithms have also been used in determining BLDC parameters [
6,
20]. However, these works determine the lumped parameters of the transfer functions used in the control design stage rather than the machine parameters. Some of the most used algorithms are based on a least-squares (LS) estimate. This approach compares the measured output with the modeled output and minimizes their difference. Assuming an accurate model, the LS method provides a versatile, efficient, reliable, and easy to implement parameter estimation method [
21]. In particular, the recursive least-squares (RLS) is a modified version of the LS that can be implemented online, allowing the use of sizable sets of measurements, and solving the minimization problem using an efficient matrix inversion method [
21,
22]. These characteristics allow to determine the dynamic model parameters and improve the performance of a linear speed controller [
23]. In [
2] the RLS algorithm was used to determine nonlinearities of the model, such as Coulomb friction coefficient, back-emf harmonics, and cogging torque coefficients. In [
7], the minimum cogging torque coefficients are determined using RLS. In [
24], the stator resistances are estimated using the RLS algorithm in a torque ripple minimization scheme.
In previous works, a notable disadvantage is that the number of estimated parameters of the model is limited [
9,
10,
14,
24,
25], the estimated parameters are typically lumped [
6,
18,
20], or are intended to refine nonlinear behavior of the machine [
2,
7]. Moreover, the parameter estimation schemes are established as an intermediate step to tune and test controllers. On the other hand, in [
4] an estimation of the full model parameters is obtained but makes use of a frequency domain approach, which is less intuitive and is limited by the laboratory equipment available. The aim of this work is to propose an easy, reliable and performable strategy for the entire identification of parameters contained in the dynamic model of a BLDC motor for control purposes, requiring a minimal number of experimental measurements. The method requires only the measurement of two-line voltages and currents and two signals of hall effect position sensors instead of three. The electrical parameters are determined through two tests which are accomplishable using a conventional data acquisition system of electrical signals. The mechanical parameters are determined using the RLS algorithm. For this stage, the electric measurements are used to estimate the instantaneous torque, which in turn is used as input to the RLS algorithm for the mechanical identification. Additionally, the validity of the estimated parameters is assessed against manufacturer information, as well as through numerical simulation using the state space model. Moreover, a real-time implementation of a well-known speed control strategy is presented. Our methodology can be applied for the parameter estimation in other electrical machines, such as brush DC motor, brushless AC, and reluctance machines.
This paper is structured as follows. In 
Section 2 the model equations and the parameters involved are presented; in 
Section 3 the tests used to determine the parameters are described alongside a brief description of the RLS algorithm; 
Section 4 briefly outlines the experimental setup, details the results of the tests comparing with information provided by the manufacturer and their validity is tested. Finally, 
Section 6 presents the concluding remarks of this work.
  2. Mathematical Modeling and Problem Formulation
The BLDC motor is a three-phase machine, whose windings are typically wye-connected. Its dynamic behavior can be described by the following system of equations:
      
Equation (
1a) is a matrix equation that represents the electrical dynamics of the motor. The bold terms 
, 
 and 
 are the voltage, current and flux linkage vectors, and are of the form 
, where 
 and 
c are the phases of the machine. The first term on the right-hand side of (
1a) represents the ohmic voltage drop across the stator phase resistance 
r, and the second term represents the voltage induced by the time-varying currents. Equation (
1b) describes the dynamics of the rotor speed 
. This is done through the torque balance between the inertial and damping torques—produced by the rotor inertia 
J and damping coefficient 
b—with the input electromagnetic torque 
 and load torque 
.
The flux linkages can be modeled by considering linearity in the magnetic core and balanced currents with the expression
      
      where the first term on the right-hand side yields the vector of flux linkages due to the magnetic field produced by the stator time-varying currents and the second term is the vector of flux linkages due to relative motion between the stationary stator windings and the rotary PM. The inductance 
ℓ represents the effect of self and mutual induction in the stator windings carrying balanced currents. The flux linkages due to the magnetic field produced by the PM 
 are, however, dependent on the magnet arrangements and the winding uniform distribution. This is taken into account in [
26] by modeling these flux linkages as quadratic functions of rotor position, so that the time-derivative of the flux linkages leads to trapezoidal back-emf waveforms, whose magnitudes are proportional to the rotor speed 
, the back-emf constant 
 and the number of poles 
P. The induced voltages due to the rotor-produced flux linkages are
      
      where 
 is a vector of trapezoidal functions of the rotor position (radians) 
, with magnitude 1 and phase angle of 120 
. These voltages are referred to as back electromotive force (emf) or internal voltage. Here, as in (
1a), this vector has the form 
.
The developed torque is obtained by the vector product
      
The ideal form of 
 and 
 are shown in 
Figure 1. It can be observed that the currents are AC square waves of amplitude 
 in discontinuous-current mode, i.e., are zero in 60
 intervals and are positive or negative in 120
 intervals. This mode of operation is called 120
 commutation, and ensures current flows through only two phases at any given time. The flat intervals of the trapezoidal back-emf waveforms correspond to those of the currents and, as a result, a constant torque 
 is produced (see 
Figure 1). Nevertheless, as a result of the armature reaction and other parasitic effects, the back-emf waveform is never flat and the developed torque is not constant, but rippled [
27].
  BLDC Model
Using the expressions derived in previous sections, the mathematical model of a BLDC motor is typically developed under the following assumptions: The power converter that generates the necessary source waveforms is comprised of ideal components, the stator windings are wye-connected and symmetric, the magnetic materials are considered linear, and the ideal current and back-emf waveforms produce a constant torque. Accordingly, Equations (
1a) and (
1b) take the form
        
In most applications, the neutral point of the BLDC is unaccessible and the measurements must be made in a line-to-line basis. The formulation of the BLDC model (line quantities) under these assumptions is therefore [
1,
28]
        
        where the vectors with an 
L subindex are of the form 
. Note that the line currents in (6) do not have a strict physical meaning as the voltages, but are rather the result of the manipulation of the phase equations. An important consequence of using line quantities in the model is that the winding are no longer in discontinuous-current mode, which means that the current does not return to zero in every period and their magnitudes along with the back-emf waveforms are affected by a factor of 2. These waveforms are also shown in 
Figure 1. Equation (6) is useful because it naturally provides a 120 
 commutation. In any commutation interval, the two phases conducting 
x and 
y are modeled by the voltage equations
        
However, due to the fact that phases 
x and 
y are connected in series, the current flowing through them is the same but with opposite signs, i.e.,  
. Therefore, the following simplification can be made:
        where 
 and 
 are the terminal resistance and inductance, respectively.
  4. Experimental Setup and Results
Several tests were performed on a four pole BLDC motor of known parameters. Two voltage and two current sensors were used to measure the line voltages (
 and 
) and currents (
 and 
). The rotor position and speed were measured using two Hall-effect sensors and an incremental encoder. The three-phase waveforms that power the BLDC were generated using a three-phase IGBT-based inverter. The electrical signals were measured using a National Instruments analog data-acquisition board (DAB), labeled PCI-6602 in 
Figure 2a, and the signals of the incremental encoder using a National Instruments digital DAB, labeled PCI-6621 in 
Figure 2a. The latter was also used to generate the gate signals to drive the inverter according to the algorithms programmed in Simulink for the no-load tests and the PI control validation tests. The schematic diagram is is shown in 
Figure 2. The  voltage, current and position sensors are labeled VS
, CS
 and PS, respectively. Additional components are shown in 
Figure 2, such as conditioning circuits for the electrical signals, an optoisolation stage to separate the logical stage from the power stage, and a DC machine mechanically coupled to the BLDC motor for the open-circuit tests. The measured data was acquired and analyzed using Simulink Real-Time, Simulink, and MATLAB, from The Mathworks, Inc. The sample time of voltage, current and Hall-effect sensors was 
.
  4.1. Resistance and Inductance Estimation
To determine the terminal resistance 
 and inductance 
 of the BLDC motor, a constant DC voltage was applied to two terminals of the motor and the voltage and current were measured. This setup is shown in 
Figure 3.
This test was performed for the three phases and different values of 
. The applied voltages were limited by the rated current of the motor and the power source used. The current 
 flowing through the phases connected to the power source was measured and used to determine the electric steady-state 
 and the terminal resistance 
 using (
11). The time constant 
 was determined using the data-acquisition system and was used along with the terminal resistance to compute the terminal inductance 
 for each phase using (
11). 
Table 1 show the measured voltage, current and time constant. The fourth column shows the resistance 
 computed using (
11) and the values shown in the second and third columns. The fifth column shows the terminal resistance value computed by subtracting from 
 the resistance of the wires used to connect the elements of the circuit, which equals 
. The last column shows the value of inductance computed from each test using (
11). The resulting parameters for each test were averaged to yield the estimated values 
 and 
 and the corresponding uncertainties were computed as the standard error for the number of tests performed. These results are shown in the bottom rows of 
Table 1.
The results were substituted in Equation (
10) and compared with the experimental results. This is shown graphically in 
Figure 4: The measured current for three of these tests is displayed with continuous lines. The dashed lines are the results obtained by substituting the determined parameters in (
10) along with the corresponding measured voltage. For each test, a shaded area is shown, which represents the response within the uncertainty intervals.
It can be seen that the experimental results are into these intervals for the first-order approximation (
9) for time values above 
. Below this time, neither response falls within the expected estimated region. As can be seen in the 
Figure 4, the experimental curves are those of a higher order dynamic system, which reveals the deficiencies of the first-order model approximation used in this test. This difference is due to dynamics, such as magnetic nonlinearity, or the rotor position, that are not considered in the utilized model. Regarding the rotor position, it is worth mentioning that the tests were performed by letting the rotor align itself to the field produced by driving current through the windings under study and locking it in that position. So for each phase the tests were made in similar conditions regarding the initial position of the rotor and the respective magnetic flux path.
  4.2. Back-emf Constant
The procedure described in the previous section for the open-circuit test was performed by coupling a controlled DC motor to the shaft of the BLDC motor. The line voltages were measured using voltage sensors and the speed was determined with an incremental encoder. 
Figure 5 shows the results of this test at different speeds, (12, 16, and 22 
) displaying the obtained voltage measurements 
 divided by the steady-state rotor speed 
 of the respective test, i.e.,
        
It can be readily seen that the waveforms have the same amplitude regardless of the speed, as expected, from the fact that the shape functions have fixed amplitudes. It can also be seen that the waveforms are not ideally trapezoidal. This is due that the waveform is heavily dependent upon how the PMs are arranged in the machine and not every magnet array yields the trapezoidal back-emf shown in 
Figure 1. In addition to this the measured quantities are line voltages, so the flat-top intervals are shorter (cf. 
Figure 1). For each test, the peak values of the generated voltages were averaged to determine the amplitude of the induced voltages 
, the rotor speed 
 was measured, and the back-emf constant was determined by substituting these values and the number of poles 
 in (
14). The results from every test are shown in 
Table 2. The last column shows the back-emf constant for each test computed using (
14). As before, the estimated parameter was obtained by averaging these values, and the uncertainty was computed as the standard error. The estimated parameter during this test is shown in the bottom rows of 
Table 2.
  4.3. Moment of Inertia and Damping Coefficient Estimation Using RLS
A no-load test was conducted to determine the mechanical parameters of the motor. The test consisted of starting the motor from standstill to a speed within its operating range. This was achieved by sensing the rotor position and determining the commutation logic to turn on the corresponding phase sequentially. The magnitude of the applied voltage was determined by the well-known volts per hertz relationship, used in scalar control strategies for induction motors. The speed was varied at equal time intervals for 6 
. The input torque was calculated using the current and rotor position measurements and Equation (
4). However, because of the sampling rate, the non-ideal waveforms and the measurement noise, the resultant torque was excessively noisy. This poses a problem regarding the RLS algorithm, because of the first-order approximation used. The torque signal was therefore smoothed using a moving median filter prior to being input to the algorithm. This smoothing strategy was chosen to remove as much outliers as possible from the torque signal by taking the median of windows of 100 samples, without significantly affecting its dynamics.
The setup for the RLS identification algorithm considers the following values
        
There is no standard methodology for choosing a forgetting factor. In general, values close to 1 are rapidly convergent but very noise-sensitive. This tradeoff was considered in the choice of , which was tuned after several trials on the algorithm using the input torque data. The sample time was selected considering that the measurement of the Hall-effect sensors used in the commutation algorithm was acquired using the same board as the voltage and current measurements. The initial parameters  were chosen arbitrarily as well as the initial correlation matrix , which was required to be positive definite.
Using this configuration and the filtered torque signal, the algorithm was run to determine the discrete parameters 
 and 
 (these results are shown in 
Figure 6). 
Figure 6a,b show the parameter trajectory during the test where both signals can be seen to have a significant noise component. Nevertheless, a trend can be established by eliminating the outliers in the resulting data. 
Figure 6c shows the output error 
 for the test. It can be seen that the algorithm tends to minimize the output error despite the parameters are not converging to a constant value. The mean values of the obtained parameters are:
Substituting these parameters into Equation (
18) and running the algorithm using an input torque of the same magnitude as the measured torque yields a very approximate output speed compared to the measured one, however, a steady-state error can be appreciated during the whole tests, which reveals a poor estimate of the parameter 
 and, by extension, of the damping coefficient. In fact, this parameter is the one that most differs from the expected value, as presented in 
Section 4.4.1. This is shown in 
Figure 6d.
Solving (
21) for 
 and 
, these parameters are given by:
        and the moment of inertia and the damping coefficient are in turn given by (
17). Substituting (
29) into (
30) and (
17), the estimated mechanical parameters are shown in 
Table 3.
        
  4.4. Validation
In this section the validity of the estimated parameters is assessed.
  4.4.1. Manufacturer Data
All the obtained parameters are summarized in 
Table 4, along with the parameters provided by the manufacturer. It can be seen that, except for the damping coefficient, all parameters were determined within the uncertainty bounds of both the manufacturer data and the estimated data. The discrepancy in the value of the damping coefficient may be due to several different reasons: The manufacturer employed a different model than the one used in this work, the motor used during these tests was in service for several years and it may have suffered damages or alterations, the friction model comprised very specific operating regimes, such as no-load, same initial conditions for every test and unidirectional rotation, amongst others. Besides, friction phenomena are known to be non-linear and dependent on many factors besides the ones that were modeled in this work. Therefore, the value of the estimated damping coefficient should only be considered valid under the conditions in which the tests were performed.