Electric Power Steering (EPS) systems utilize an electric motor, such as a Permanent Magnet Synchronous Machine (PMSM), to provide steering assist to a driver. One control technique is called Field Oriented Control (FOC), which allows the sinusoidal three-phase motor voltage and current signals to be transformed into signal based on a synchronously rotating reference frame, commonly referred to as the direct-quadrature (DQ) reference frame, where the motor voltages and currents become direct current (DC) quantities. The DQ reference frame transformation requires positional information of the machine, which is usually obtained by using a physical position sensor. As an alternative, sensorless control (SC) refers to the class of control schemes in which the motor is controlled without a physical position sensor. In contrast with its sensor-based counterpart, SC-FOC schemes employ observers or estimators to obtain the position of the machine, however, the overall control architecture is similar to a sensor-based FOC scheme.
In one embodiment of the invention, a control system for monitoring operation of an electric motor includes a plurality of position sensors configured to measure a position of the electric motor, an indirect position estimation module configured to indirectly estimate the position of the motor, and an error monitoring module. The error monitoring module is configured to perform at least one of: comparing a measured position from the plurality of position sensors to an estimated position from the sensor position estimation module, and detecting a failure of at least one of the one or more position sensors based on the comparison; and calculating a difference between the measured position from one of the plurality of position sensors and the measured position from another of the plurality of position sensors, and causing the indirect position estimation module to initiate estimation of the position of the motor based on the difference.
In another embodiment of the invention, a method of monitoring operation of an electric motor includes measuring a position of the electric motor by a plurality of position sensors during a field oriented control (FOC) operation mode. The method also includes calculating, by an error monitoring module, a difference between the measured position from one of the plurality of position sensors and the measured position from another of the plurality of position sensors, and based on the difference exceeding a selected threshold, causing an indirect position estimation module to initiate an indirect estimation of the position of the motor.
These and other advantages and features will become more apparent from the following description taken in conjunction with the drawings.
The subject matter which is regarded as the invention is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other features, and advantages of the invention are apparent from the following detailed description taken in conjunction with the accompanying drawings in which:
The following description is merely exemplary in nature and is not intended to limit the present disclosure, application, or uses. It should be understood that throughout the drawings, corresponding reference numerals indicate like or corresponding parts and features.
Referring now to
As shown in
In various embodiments, a control module 40 controls the operation of the steering system 12 and/or the vehicle 10 based on one or more of the sensor signals and further based on error detection system and method of the present disclosure.
Embodiments described herein can be part of a steering system such as an electrical power steering (EPS), driver assistance system and/or vehicle control system (e.g., autonomous or semi-autonomous steering system). It is noted that the embodiments described herein may be employed in conjunction with any device or system that utilizes an electric motor or motors.
Referring to
A reference current calculation module 52 receives the motor velocity from the position and velocity estimation module 44. In addition, the reference current calculation module 52 receives a desired torque from the steering assist unit 18. Based on the desired torque and the motor velocity, the reference current calculation module 52 calculates a current command that is output to subtraction block 58. Subtraction block 58 subtracts a DQ reference frame current from the current command to generate a difference, which is provided to the current regulator module 60. The DQ reference frame current may be generated by a transform module 61, which is in communication with the motor 42, the position and velocity estimation module 44, the motor 42, and the reference current calculation module 52. Based on the difference, the current regulator 60 generates a motor voltage command. The motor voltage command is sent to a duty cycle calculation module 64, which analyzes the motor voltage command and generates a duty cycle signal. The duty cycle signal is used by an inverter to apply a motor voltage representative of the motor voltage command to the motor 42. In one embodiment, an inverter applies the motor voltage. The position and velocity estimation module 44, reference current calculation module 52, current regulator module 60, and the duty cycle calculation module 64 may be a part of the control module 40, but are not so limited.
A control system, such as the control module 44 and/or aspects of the control architecture, is configured to operate under multiple control modes. A first control mode is utilized in situations where position sensors are working properly and no sensor errors are detected. The first control mode utilizes Field Oriented Control (FOC), which uses information from physical position sensors (direct measurements) for the DQ reference frame transformation. A second control mode may be utilized when one or more of the position sensors have failed. An example of the second control mode is referred to as Fault Tolerant Control (FTC), which is a mode of operation of the FOC system where normal operation of the physical position sensor has failed and positional information is obtained indirectly (without a physical position sensor) from an observer or estimator. The FTC mode may use sensorless control (SC), which involves controlling the motor without the use of one or more of the position sensors. In this mode, an observer-based position measurement is used.
In a position sensor-based FOC system, there is always a possibility of failure of position sensors. The FTC mode can be triggered or used in situations where one or more of the position sensors have failed. For example, the FTC control mode is provided as a backup so that the motor can be controlled without significant interruption when operation of some or all of the physical position sensors have failed. Accordingly, in one embodiment, embodiments described herein allow for transition from a FOC mode to a FTC mode.
Detection of sensor failure is discussed with reference to
In this embodiment, the position and velocity estimation module 44 includes an error monitoring module 80, a position calculation module 82, and a signal selection module 84. The selection module 84 may generate a flag or diagnostic signal to trigger the FTC mode, e.g., by transmitting the diagnostic signal to a FOC module 85.
The position and velocity estimation module 44 (or other suitable processor, processing unit or module) is configured to receive position signals from position sensors 86, and also to indirectly estimate a motor position without using a position sensor, such as by using an observer-based technique. The module 44 may detect a sensor error based on a comparison between the indirectly estimated position and one or more position signals from one or more position sensors. The module 44 may also be configured to initialize a sensorless control algorithm in response to detecting an error, and/or prompt a fault tolerant control mode if all physical sensors have failed or otherwise presented an error.
The motor position may be indirectly estimated using any suitable method or technique. In one embodiment, an estimate of the position is calculated using an observer based on various input parameters, such as the actual phase currents, applied voltages and machine parameters as inputs used to produce position and velocity estimates.
There are numerous algorithms for estimating position of a PMSM machine, and these vary specifically for different operating speed regions. In general, robust techniques such as those based on Sliding Mode Control (SMC), can be used for estimating position of all kinds of PMSM machines (salient or non-salient pole) in the high speed region. For such observers, the diagnostic may be implemented as a conditional diagnostic, i.e., which is disabled when the speed is below a calibratable threshold. The speed signal may be an estimated quantity or may be obtained by differentiating the position signal from one of the physical sensors.
One of the methods for estimation involves estimation of position and velocity of PMSM from the stator flux linkage which is obtained using the voltage and current signals of the motor.
In one embodiment, the estimated position is generated by a position observer that estimates position based on a plant model of the motor in the synchronous or DQ reference frame. Stator flux linkages are calculated from the voltage and currents using discrete integration, initial values of the flux linkages are calculated from an initial position (θ0), and an initial current magnitude and motor position angle are calculated therefrom.
The control system (e.g., the position and velocity estimation module 44 and/or the error monitoring module 80) detects an error condition due to the failure of one or more position sensors by comparing the estimated position (e.g., based on an observer) to measured positions from the position sensors. In one embodiment, the system includes two or more position sensors. An “error condition” refers to a condition in which a physical position sensor has failed or in which there is a significant potential for failure.
Error conditions can be detected using the plant model. In one example, current estimates using the plant model are generated in the stationary reference frame as Ia1 and Iβ1. Current errors ΔIαe1 and ΔIβe1 are calculated as the difference between the estimated and measured currents. Position errors Δθα[n] and Δθβ[n] for a position sensor n are then calculated based on the current errors.
In one step of calculating the position errors, there is a calculation term which contains terms sin θα and cos θβ in the denominator of estimated position error equations as shown below:
Since the sine and cosine terms may become zero, a selection window based conditional checks can be generated to use the average of the two position errors or either of the two, based on which term becomes zero. A position-window based selection scheme may be utilized to compute the position error Δθ[n]. This scheme may be mathematically expressed as follows.
For example, if a position window (θW) is chosen to be
the position error is calculated exactly half the time using Δθα and Δθβ each. Note that the quality of the position signal varies with the choice of the window θW.
Detection of a sensor failure may be realized through a truth table or other comparison scheme that allow for comparison between position measurements from physical sensors and comparison between position measurements and indirect position estimates.
An example of a comparison scheme for detecting a sensor failure is shown below. In this example, there are two physical position sensors that output position measurements θ1 and θ2. An estimated position from an observer is denoted as θest. The following truth table illustrates how a comparison scheme may be implemented for a three sensors system where one of the sensor signals is estimated.
In the above scheme, a difference between the position measurements θ1 and θ2 is calculated, and a difference between the estimated position and each position measurement is calculated. If the result of any comparison exceeds a selected threshold (which may be the same or different for the various comparisons), the comparison results in a “Fail”. Whether a fault is determined for a given position sensor is dictated by the truth table.
Outputs from the comparisons may include a flag or other indicator of whether a sensor has failed or could fail. For example, the output of the above scheme is a comparison health status flag Fck (where k is the number of the sensor) indicating the health status of each individual sensor k. Further, if each sensor has self-diagnostics as indicated by a self-diagnostic health status flag Fsk, those may be used in addition to the above comparison scheme to detect failures. For instance, an AND operation may be performed between Fck and Fsk. The comparison health status flag is provided for each sensor to indicate if there is a failure or a potential failure.
As described in more detail below, position information may be obtained by the position and velocity estimation module 44 during a failure, and transmitted to an FOC module 85, for example, for processing by an estimation algorithm.
In one embodiment, the error monitoring module 80 or other suitable control system is configured to determine whether an error condition exists (e.g., that one or more sensors have failed or could potentially fail), and may also be configured to identify a specific sensor or sensors that have failed or otherwise presented an error. The error condition determination and/or sensor identification method is discussed in conjunction with an example of the position and velocity estimation module 44 shown in
Referring to
In one embodiment, the error signal θerr is an angular difference between the respective motor position signals of the set of motor position signals. Specifically, the error signal may be calculated by the following equation:
θerr=|θ1−θ2|
where θ1 and θ2 are the motor position signals from the primary physical position sensor and the secondary physical position sensor, respectively.
In one embodiment, the error monitoring module 80 evaluates the error signal to determine whether the error signal is greater than a preset threshold for a specified period of time. One or more flags (F) may be output to indicate that there is an error condition. A triggering flag (FIN), also referred to as an initiation flag, may be output to the position calculation module 82 in response to detecting an error signal. In addition, a transition flag FTR may be output to the signal selection module 84 to initiate transition from a FOC mode to a FTC mode as discussed further below.
For example, the error monitoring, triggering and/or detection schemes presented herein generate a triggering flag FIN which indicates a potential failure or “proximity to failure” condition and triggers an initial position prediction system and an SC algorithm. In addition, a transition flag FTR can be generated that indicates a “sensor failed” or actual failure condition and disables the position based FOC algorithm (normal operation) and triggers the FTC mode in which the FOC system is operated with the estimated position.
In one embodiment, a time invariant error detection scheme is used by the error monitoring module 80 to generate trigger flags. In another embodiment, a time-varying detection scheme is used by the error monitoring module 80 to generate trigger flags. However, other error detection schemes, including but not limited to those described below, are contemplated by this disclosure.
An embodiment of a time invariant error detection scheme is discussed in conjunction with
A time-varying error detection scheme can be used by the error monitoring module 80.
In one embodiment, the control system is configured to perform a monitoring, triggering and/or transition control method that includes detecting an error condition as described above. The control method in this embodiment includes monitoring physical position sensors via a correlation check to compare the motor position signals and determine an error signal θerr. If the error signal exceeds a first threshold (referred to herein as an initialization threshold), a potential failure condition or “proximity to failure” condition is detected and sensorless position estimation is prompted. If the error signal exceeds a second threshold (referred to herein as a transition threshold) that is higher than the first threshold, an actual failure condition is detected in which at least one sensor has failed, and the control system is prompted to transition from normal control to FTC mode. The method may also include detecting which position sensor has failed or represents a potential failure.
Based on receiving one or more flags, or otherwise when there is any indication of physical sensor failure, the control system initiates a sensorless (indirect) position estimation algorithm. In one embodiment, the sensorless position estimation process starts immediately or otherwise as soon as possible once the triggering flag FIN is raised for any type of faults on the physical position sensors. The transition flag FTR may be used to ultimately alert a field oriented control module 86 to transition into a fault tolerant control mode.
For example, as shown in
If a potential error condition is detected, a triggering flag FIN is output to the position calculation module 82. In the example of
If the error signal θerr exceeds a second threshold (e.g., a transition threshold), a transition flag FTR is generated. For example, the error detection sub-module 88 outputs the transition flag to the signal selection module 84. The signal selection module 84 receives the transition flag, along with measured position information and an estimated motor position {circumflex over (θ)} generated by the position observer 108.
The status of the error indication flag FIN determines the starting of the sensorless control initialization process. As soon as the FIN status changes to TRUE state, which implies that there is a potential of sensor failure, an algorithm goes through certain initialization steps to initiate the sensorless position estimation algorithm.
The position calculation module 82 is configured to execute an algorithm to accomplish one or more tasks upon receiving the triggering flag or other indication of a potential error or proximity to failure condition. A first task is to predict the correct motor position at the present time (i.e., when FIN just gets set), which is referred to herein as an “initial position.” A second task is to detect exactly which sensor (e.g., primary or secondary) is faulty or potentially faulty.
In one embodiment, the position calculation module 82 predicts the initial position, e.g., using the initial prediction sub-module 106. Upon receiving the triggering flag, the initial position is performed by determining a time duration before the actual beginning of the fault of the motor position sensor.
In one embodiment, the initial position is calculated by determining a time duration (tfault) between the last sample time or other time at which no error condition was detected, and the present time at which the fault occurred or at which a potential fault was detected. Since the fault thresholds are usually small and velocity is an inherently slow varying signal, it can be assumed that the velocity does not change much between the time the fault occurred and when FIN is set.
First, an initial sample number k0 is picked, which is sufficiently high in order to obtain a velocity sample from the pre-fault period. The initial sample number represents a position signal sample that was taken from the position sensors prior to detecting the fault and/or error condition. Then, an initial velocity ω0 is obtained from a velocity buffer or other storage location as follows.
ω0=[n−k0],
where n is a sample number at the time that the fault or error condition was detected, and co is the motor velocity at the sample number n.
Note that k0 may could be a fixed value, or may be calculated from the initialization threshold and an averaged (either simple or weighted) value of a fixed number of previous velocity samples (ωAVG). Further, to avoid inclusion of velocity transients caused by position errors, the value of ωAVG could be filtered as well.
Once the initial velocity is obtained, tfault may be calculated as follows:
where δIN is the initialization threshold. Thereafter, the approximate sample number k at which the system was in pre-fault condition is obtained as follows.
The pre-fault speed ωa is then calculated using the equation shown below.
ωa=ω[n−k]
Finally, the correct initial position is calculated as follows.
θ0=θ1[n−k]+ωatfault
Proper initialization of sensorless control requires knowledge of position and velocity signals during the pre-fault condition. For this purpose, a buffer such as a rolling or circular buffer may be utilized. The total time taken for triggering is dependent on the instantaneous velocity, the initialization threshold (δIN), and the type of position sensor error. For instance, if the velocity of the machine is very slow when the sensor begins to fail, the total time taken for FIN to set might be very large since the buffer size in an embedded system must be large enough to store the signal values from pre-fault period, irrespective of the fault conditions. However, since the total memory available in a typical microprocessor employed for an embedded application is not unlimited, the size selection must be done judiciously.
Buffer size (b) may be selected using variables including a minimum system velocity ωmin, sampling time Ts and the threshold δIN as shown below:
It can be seen from the above equation that as ωmin gets smaller, a larger b is needed for a given δIN. Alternatively, δIN may be reduced to keep the buffer size reasonable, as long as it is kept large enough to avoid an erroneous setting of FIN. If b is too small, then it is possible that no pre-fault data is retained in the buffer for initialization.
Since there is typically exists a maximum limit on the buffer size, it is possible to optimize the buffering of the velocity signal by storing them at a slower rate. This concept is referred to as decimation. Decimation is possible because velocity is fundamentally a low bandwidth signal as compared to position in an EPS system. It is also possible to decimate position signals if some amount of error in the initial condition may be tolerated.
Although once tfault has been determined, the initial position prediction does not depend on the knowledge of which position sensor has failed. However, it may sometimes be useful to identify the faulty sensor in order to initialize the system, as an additional layer of coverage.
In one embodiment, the following calculations are performed in order to identify the faulty sensor. In this embodiment, the position sensors include a first sensor that outputs a position signal θ1, and a second sensor that outputs a position signal θ2.
θ1t=θ1[n]+ωatfault
θ2t=θ2[n]+ωatfault
θ1et=|θ1t−θ2[n]|
θ2et=|θ2t−θ1[n]|
where θ1t and θ2t are position values at a time associated with the initial position.
The values θ1et and θ2et are the “post-correction error values” of the two position signals. The faulty signal is determined by checking which value (e.g., θ1et and θ2et) is closer to zero. This is based on the idea that the error value that goes to zero after correction is the one that needed the correction in the first place, and is thus the faulty one.
After detecting the faulty position sensor, a pre-fault position value may be obtained from the buffer of the healthy sensor.
One the faulty sensor is detected, the position signal from the other sensor (θx) may be used to compute the initial position as shown below.
θ0=θx[n−k]+ωatfault
With the capability of detecting the faulty sensor, it is possible to only initialize the estimators but not enter FTC mode, and use the healthy sensor(s) to continue normal FOC operation, while utilizing the estimated position to diagnose the healthy sensor. Thus, in one embodiment, the system is configured to transition to FTC mode when all physical position sensors have failed.
If all the physical position sensors become faulty in an EPS system, the system typically goes to shut-down mode and the driver does not receive any torque assist from the motor. But using embodiments described herein, this situation can be avoided by using the estimated position signal to control the motor. Using the estimated position, the system may be kept running to provide assist for a certain amount of time so that, e.g., a vehicle can be driven to a safe spot (which is sometimes called a “limp-aside” operation mode).
In one embodiment, the method at 121 receives a set of motor position signals from a motor vehicle sensor (one of the sensors 31-33) that generates the signals. In one embodiment, the motor vehicle sensor samples the motor position signals at a given frequency. At 122, the method generates an initialization flag signal and a transition flag signal based on the set of motor position signals. The set of motor position signals may be from a primary motor position sensor and a secondary motor position sensor, for example. At 123, the method estimates a position of the motor based on the initiation flag signal and the set of motor position signals. At 124, the method includes enabling a fault tolerant operation algorithm for the motor based on the estimated position, the transition flag signal, and an actual position provided by the at least one motor position sensor.
While the invention has been described in detail in connection with only a limited number of embodiments, it should be readily understood that the invention is not limited to such disclosed embodiments. Rather, the invention can be modified to incorporate any number of variations, alterations, substitutions or equivalent arrangements not heretofore described, but which are commensurate with the spirit and scope of the invention. Additionally, while various embodiments of the invention have been described, it is to be understood that aspects of the invention may include only some of the described embodiments. Accordingly, the invention is not to be seen as limited by the foregoing description.