Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
MOTOR COIL TIMING METHOD
Document Type and Number:
WIPO Patent Application WO/2015/097440
Kind Code:
A1
Abstract:
A switched reluctance motor is controlled by sensing the position of the rotor of the motor to provide indications of the timings of one or more positions of the rotor per revolution of the rotor,deriving from those indications, indications of the timings of one or more estimated positions of the rotor between the timings indicated by the sensing, and then energising the stator coils of the motor at those times.

Inventors:
BOUALLAGA KAMEL (GB)
DUPUIS DOMINIQUE (GB)
MANUEL GONCALO FILIPE SIM ES (GB)
Application Number:
PCT/GB2014/053710
Publication Date:
July 02, 2015
Filing Date:
December 16, 2014
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
VALEO AIR MAN UK LTD (GB)
International Classes:
H02P25/08; H02P6/16
Foreign References:
GB2264407A1993-08-25
EP0813289A11997-12-17
US5739663A1998-04-14
Attorney, Agent or Firm:
FORD, James Marcus (London Greater London WC1R 4PQ, GB)
Download PDF:
Claims:
CLAIMS

1. A control circuit for a switched reluctance motor,

comprising :

controllable switches for connection to stator coils of the motor to control whether the coils are energised,

a single position sensor responsive to the position of the rotor to provide indications of the timings of one or more positions of the rotor per revolution of the rotor,

a position interpolator connected to receive the

indications of timings of the rotor positions from the single position sensor, and to provide one or more indications of the timings of one or more estimated positions of the rotor between the timings indicated by the position sensor,

a switch controller connected to receive the indications of the timings from the position interpolator to determine timings of switch control signals connected to operate the switches .

2. A control circuit as claimed in claim 1 wherein the switch controller is also connected to receive the indications of the timings from the position sensor to determine timings of switch control signals connected to operate the switches.

3. A control circuit as claimed in claim 1 or claim 2 wherein the position interpolator is connected to estimate the one or more positions of the rotor based on the assumption that the rotor speed is currently constant.

4. A control circuit as claimed in claim 3 wherein the

position interpolator is connected to estimate the one or more positions of the rotor based on the assumption that the rotor speed is currently constant, that speed being a measured speed of the rotor.

5. A control circuit as claimed in claim 4 wherein the

position interpolator is connected to receive the measured speed based on the indications of the timings of the rotor position from the position sensor.

6. A control circuit as claimed in claim 1 or claim 2 wherein the position interpolator is connected to estimate the one or more positions of the rotor taking into account the

acceleration of the rotor.

7. A control circuit as claimed in claim 6 wherein the

position interpolator is connected to estimate the

acceleration of the motor from measurements of the speed of the rotor, to estimate the future speed of the rotor from the estimate of the acceleration and to estimate the time rotor will reach a particular position using that future speed.

8. A control circuit as claimed in claim 6 wherein the position interpolator is arranged to take into account the acceleration of the rotor by applying a correction factor, the timings of the one or more estimated positions of the rotor being based on an initial estimation which is then adjusted by the correction factor. 9. A control circuit as claimed in claim 8 wherein the correction factor is read from a look-up table, and the control circuit comprises a memory module in which the look-up table is stored. 10. A control circuit as claimed in claim 9 wherein the values of the correction factor in the look-up table have been empirically obtained.

11. A control circuit as claimed in any preceding claim comprising a control loop connected to provide the switch controller with rotor angles, dependent on a required motor torque, at which to operate the switches, the switch

controller being connected to base the determination of the timings of the switch control signals also on those angles.

12. A control circuit as claimed in claim 11 wherein the control loop comprises

a speed estimator connected to receive the indications of the timings of one or more positions of the rotor and to provide therefrom a rotor speed value,

a subtractor connected to receive the rotor speed value and form the difference between that and a speed command value to from a speed error value,

a loop controller connected to responsive to the speed error value to increase a torque command if the rotor speed value is less than the speed command value and to decrease the torque command if the rotor speed value is more than the speed command value,

a lookup table responsive to the torque command and the rotor speed value to provide the rotor angles. 13. A control circuit as claimed in claim 12 wherein control loop comprises an offset corrector connected to adjust the rotor angles from the lookup table with values allowing for an offset of the position sensor. 14. Apparatus comprising:

a switched reluctance motor, comprising a rotor and comprising stator coils,

a control circuit as claimed in any one of claims 1 to 13 connected as claimed to the stator coils of the motor, a supercharger having a compressor wheel coupled to the rotor of the motor to be driven thereby.

15. A method of controlling a switched reluctance motor, comprising:

sensing the position of the rotor of the motor, using a single sensor, to provide indications of the timings of one or more positions of the rotor per revolution of the rotor,

deriving from the indications of timings of the rotor positions indications of the timings of one or more estimated positions of the rotor between the timings indicated by the sensing, and

energising stator coils of the motor at times determined in response to the indications of the timings of the estimated positions.

16. A method as claimed in claim 15 comprising energising stator coils of the motor at times determined in response to the indications of the timings the rotor positions.

17. A method as claimed in claim 15 or claim 16 wherein the deriving comprises estimating the one or more positions of the rotor based on the assumption that the rotor speed is

currently constant.

18. A method as claimed in claim 16 wherein the estimating is based on a measured speed of the rotor.

19. A control circuit as claimed in claim 18 wherein the measured speed is based on the indications of the timings of the rotor positions.

20. A method as claimed in claim 15 or claim 16 wherein the deriving comprises estimating the one or more positions of the rotor taking into account the acceleration of the rotor.

21. A method as claimed in claim 20 wherein the estimating comprises: estimating the acceleration of the motor from measurements of the speed of the rotor, estimating the future speed of the rotor from the estimate of the acceleration and estimating the time rotor will reach a particular position using that future speed.

22. A method as claimed in claim 20 wherein the estimating comprises :

(i) making an initial estimate of the timings of the one or more estimated positions of the rotor; and (ii) adjusting the initial estimate by applying a correction factor to thereby obtain the timings of one or more estimated positions of the rotor.

23. A method as claimed in claim 22, wherein the correction factor is read from a look-up table.

24. A method as claimed in any one of claims 15 to 23 wherein the switched reluctance motor is driving a compressor wheel of a supercharger.

25. Apparatus substantially as herein described with reference to, and as shown in Figures 8, 9 or 10.

Description:
MOTOR COIL TIMING METHOD

Field of the invention

The present invention relates to switched reluctance motors and in particular to a method of timing the operation of the coils of the motor.

Background

A typical switched reluctance motor is shown in Figures 1A, IB and 2 to 4. This example has a combination (which is frequent) of six, preferably evenly, spaced poles 2on the statorl and four, preferably evenly, spaced poles 3 on the rotor 4. In this example, the poles of the stator project inwardly from a stator ring 5, the ring providing a path of low reluctance material between the stator poles. The rotor is formed of a stack of cross-shaped

laminations, also of low reluctance material. Therefore each rotor pole is connected to the diametrically opposite rotor pole by a low reluctance path, for reasons which will become apparent. So, as marked, pole U is connected by a low

reluctance path to pole U' and pole V to pole V .

Each pole of the stator is wound with a coil 6 and the coils are arranged in pairs, each pair comprising the coils at opposite ends of a respective diameter through the rotational axis of the motor. In this case therefore the pairs are coils AA' , BB' and CC , as marked. The coils of a pair are energised at the same time, with current from a motor control circuit 10 (Figure 5), and in a sense such that one provides a magnetic field towards the rotational axis and one away from the axis. In the Figures the arrows on the coils represent the direction of the current in the coil above the plane of the paper and the dashed arrows represent the magnetic flux. Together the magnetic flux lines produced by the energised coils and their respective poles are arranged generally along the diameter between them and then follow the stator ring (in both

circumferential directions) to the other energised coil of the pair.

The rotor modifies the distribution of magnetic field lines in the space between the energised pair of stator poles. Positions of the rotor in which a pair of diametrically opposite poles of the rotor are aligned along the diameter between the energised pair of stator poles are positions of the rotor that have minimum reluctance for the magnetic circuit that comprises the rotor between the aligned rotor poles, the energised stator poles and the stator ring. The example of rotor poles U and U' being aligned between stator poles A and A' is shown in Figure IB. Such a position is therefore a position of minimum magnetic energy. In a non- aligned position, e.g. as in Figure 1A the magnetic flux still flows along the low reluctance path between the poles of rotor and so the flux is diverted from the diameter between the energised poles of the stator, with the result that it has to cross larger air gaps between the poles of the rotor and stator, increasing the reluctance of the magnetic circuit and the magnetic energy. So if the rotor is not aligned there is a torque on it drawing it towards the aligned position. At operational rotation speeds the motor is driven by energising pairs of stator coils in turn to draw the poles of the rotor forward in the direction of rotation. So when, for example, the rotor is in the position of Figure 1A and the rotor is rotating clockwise, so that rotor poles U and U' are approaching stator poles A and A' , the coils of A and A' are energised so that U and U' are drawn towards A and A' . When the position of Figure IB is reached in which U and U' are aligned with coils A and A', A and A' are turned off (Figure 2) so that the rotor can continue to rotate without being slowed or drawn back to A and A' . At this point also rotor poles V and V are approaching stator poles of coils B and B' so B and B' are energised (Figure 2) to draw stator poles V and V onwards in the clockwise direction towards B and B' .

When the position of Figure 3 is reached in which V and V are aligned with coils B and B' , B and B' are turned off so that the rotor can continue to rotate without being slowed or drawn back to B and B' . At this point rotor poles U' and U are approaching the stator poles of coils C and C so coils C and C are energised to draw rotor poles U' and U onwards in the clockwise direction towards C and C .

When the position of Figure 4 is reached in which U' and U are aligned with C and C the coils C and C are turned off so that the rotor can continue to rotate without being slowed or drawn back to C and C . At this point rotor poles V and V are approaching the stator poles of A and A' so the coils A and A' are energised to draw stator poles V and V onwards in the clockwise direction towards A and A' .

When V and V reach A and A' the rotor has turned 90°, so, since the rotor has four fold rotational symmetry is in effect in the same position as Figure 2 and so the cycle of energising coils B and B' then C and C and then A and A' is repeated to advance the rotor the next 90°, and so on. As is known in the art the coils are switched off and on at particular angles of rotation of the rotor, for example in response to sensing signals generated by the coils as they are both driven by the currents and their inductance changes as the rotor poles pass by them. A first known motor control circuit lOis shown in Figure 5. This comprises the stator coil pairs connected in parallel across a DC power supply20. Coils A and A' , connected in parallel with each other, are energised by closing switches 21 and 22, and similarly coils B and B' by switches 23 and 24, and coils C and C by switches 25 and 26. These switches are operated by the control circuit 10, which closes the switches when the coils are to be energised. Having the coils A and A' operated by a common pair of switches 21 and 22 (similarly each coil pair B and B' , and C and C , having its own pair of common switches) is sufficient to provide the patterns of coil energisation described above. The switches 21 to 26 are provided, for example, as FET or IGBT transistors. A measure of the current is used by the motor control circuit 10 to determine the position of the rotor and in turn to determine the timings of the operation of the switches 21 to 26. In particular, as is known in the art, the coils are switched off and on at particular angles of

rotation.

In more detail, the control circuit 10 of Figure 5 senses signals generated by the coils as they are both driven by their currents and their inductance changes as the rotor poles pass by them. This inductance comprises the stator coil pairs connected in parallel across a DC power supply 20. The voltage of this supply depends on the application and might be 12V, 24V, 48V or 300V, for example. Coils A and A', connected in parallel with each other, are energised by closing switches 21 and 22, and similarly coils B and B' by switches 23 and 24, and coils C and C by switches 25 and 26. These switches are operated by a switch control unit 27, which closes the

switches when the coils are to be energised. The current in each coil pair is sensed by a resistor 28 connected in series with it to provide a resulting voltage signal that is

proportional to the current, which is used to determine the rotor positions, which are used in turn to determine the timings of the operation of the switches 21 and 22, 23 and 24, and 25 and 26. The motor control circuit 10 processes the signals from the coils in a number of stages, forming a control loop. A position estimator 30 receives the signals indicative of the coil currents and continuously calculates from them the position of the rotor and outputs a rotor position value signal 31. The calculation is performed by a microcontroller and requires a complex algorithm. A speed estimator 32

differentiates this signal with respect to time, to provide a rotor speed signal 33. The control loop is designed to control the speed of the motor to be as set by an input signal, speed command signal 35, and the difference between the speed command signal and the rotor speed signal is formed by a subtractor 36 to form a speed error signal 37. A loop

controller 38, for example in this case a proportional- integral controller, uses this signal to adjust a torque command 39 for the motor. The relationship between the torque applied by a motor to its steady state speed is generally monotonically increasing. So the controller 38 increases the torque commanded if the speed error indicates that the motor is running slower than required and reduces torque commanded if the motor is running faster than commanded. The controller 38 also filters the signals circulating round the control loop in order to smooth the response of the loop.

The motor 1 is of course not controlled directly by a torque command and the torque command 39 is converted to control angles 42 for the switches of the motor. These angles are the angles of the rotor at which the switches of the motor operated, in particular the angles at which a coil pair is turned on, the angle at which it is allowed to "freewheel", and the angle at which it is turned off.

To turn the pair of coils on both its associated switches are turned on (for coils AA' switches 21 and 22) . In the freewheel mode the switch (e.g. 21) connecting the coils to the positive supply is opened but the current continues to circulate through a diode and at the off angle both switches are opened and the current in the coil passes through the other marked diode marked to ground, dissipating over a short period after the switches are opened. (Alternatively, for the freewheel mode the switch connecting the coils to the negative supply may be opened instead, with the current continuing to flow through the coils of the pair and the other marked diode. Which of the two switches is open in the freewheel mode can be alternated in order share balance the power dissipated by the switches between them. )

The conversion of the torque command signal to these angles is performed by a lookup table 41. The angles needed to provide the torque desired are dependent on the speed of the rotor, so the rotor speed signal 33 is also provided to the lookup table 41, to provide the angles for that torque and speed. These angles are determined empirically while driving the motor while connected to its desired load.

The angles 42 produced by the lookup table are passed to the switch control unit27, which operates the switches at the angles 42 accordingly when those angles match the rotor position value signal 31. In more detail, the angles 42 supplied are the same for each coil pair and are relative to the angular position of the coil pair. The switch controller 27 keeps track of which coil pair is to be operated next and uses the rotor position value 31 modulo 30° for the comparison with the angles 42.

Circuit blocks 30, 32, 36, 38, 41 and 27 are preferably implemented by the microcontroller. A second known control circuit is illustrated by Figures 6 and 7.

Figure 6 shows the motor with a magnetic sensor ring 50 mounted on the rotor shaft 51 of the motor 1 to rotate with the shaft and hence with the rotor. The sensor ring is located along the shaft at some distance from the rotor to avoid magnetic interference from the motor itself. (That distance is not apparent in the Figure since the view is along the axis of the shaft.) The ring is magnetised radially in eight sectors, with each being magnetised in the opposite direction. Three Hall Effect sensors 51, 53, 55 are mounted a short distance outside the ring 50 and to be stationary with respect to the stator. The sensors are distributed along a section of the circumference of the ring, spaced from each other in steps of 30° in the circumferential direction. This combination means that each N to S boundary of the ring (which are distinct to the sensors from the S to N boundaries) passes the three sensors in turn, one every 30° of rotation of the rotor and ring, and then after 90°, the next N-S boundary passes them in the same order again spaced by 30°, and so on. Each time an N- S boundary passes a sensor 51, 53, 55 its associated signal conditioning electronics produces, on a respective conductor, a respective pulse signal 52, 54, 56 at that time (Figure 7) . The pulses from the three Hall Effect sensors occur therefore with the same frequency and angular separation between them as the features of the current signals passing through the coils in the control circuit of Figure 5.

These signals 52, 54, 56 are used as follows. The speed estimator 32' uses the time between the pulses to estimate the angular speed of the rotor to provide the rotor speed signal 33. (The resource intensive position estimator is not

required.) The switch controller 27' uses the pulses 52, 54, 56 on the respective conductors to time the switches for respective pairs of coils AA' , BB' , CC . It calculates an offset in time for the operation of the switches from the angles 42' supplied by the control loop and rotor speed signal. These angles 42' are first adjusted by an angle offset corrector 43 from those 42 provided by the lookup table 41 to allow for the angular position of the N-S boundaries of the magnetic ring 50 with respect to the rotor. The offset

adjustment needed (EOL (end-of-line) values 44) is measured at the end of manufacture of the motor complete with its magnetic indicator ring 50 in place on the rotor shaft, and is

programmed into the motor control circuit 10' . The offset is the difference between the angle at which a rotor pole passes a stator pole of a coil (A or B or C) and the angle at which the N-S boundary respective to that rotor pole passes the sensor 51, 53, 55 respective to that coil. This adjustment was not needed in the circuit of Figure 5 because the current signals produced by the coils are automatically aligned to the rotor poles passing the stator poles. Otherwise the rest of the circuit of Figure 7 operates in the same way as the circuit of Figure 5.

As is also known in the art, other combinations of stator and rotor pole numbers are possible for the motor. These have different cycles of energisation of the coils in order to keep the torque on the rotor in the forward direction. A common relationship between the numbers of poles is to have two more stator poles than rotor poles and to have both even in number. The choice of the number of poles usually takes into account the operating speed of the motor, the operating power, the acceptable level of torque ripple (variation in torque

supplied by the motor with angle of the rotor) , and the circuitry required.

Note finally that it is usually generally preferred in such motors for reasons of balance of torque to energise coils in pairs that are diametrically opposite to each other. _ g _

Summary of the Invention

According to the present invention there is provided a control circuit for a switched reluctance motor, comprising:

controllable switches for connection to stator coils of the motor to control whether the coils are energised,

a position sensor responsive to the position of the rotor to provide indications of the timings of one or more positions of the rotor per revolution of the rotor,

a position interpolator connected to receive the

indications of timings of the rotor positions to provide one or more indications of the timings of one or more estimated positions of the rotor between the timings indicated by the position sensor,

a switch controller connected to receive the indications of the timings from the position interpolator to determine timings of switch control signals connected to operate the switches .

By interpolating to provide timings of estimated

positions, the present invention negates the need for multiple position sensors. The control circuit preferably only

comprises a single position sensor. The position interpolator is preferably connected to receive the indications of the timings of the rotor positions from the single position sensor .

The present invention recognises that by using an

interpolator to provide the indication of the timings of the estimated positions of the rotor (between the timings

indicated by the single position sensor) , only one sensor need be provided. This simplifies the control system and may enable its cost to be reduced. In effect, the timing of the estimated positions from the interpolator can be used instead of requiring dedicated sensors to sense those timings (as is the case in the prior art example in Figure 6.) The switch controller may also be connected to receive the indications of the timings from the position sensor to determine timings of switch control signals connected to operate the switches.

The position interpolator may be connected to estimate the one or more positions of the rotor based on the assumption that the rotor speed is currently constant.

The position interpolator may be connected to estimate the one or more positions of the rotor based on the assumption that the rotor speed is currently constant, that speed being a measured speed of the rotor. The position interpolator may be connected to receive the measured speed based on the

indications of the timings of the rotor position from the position sensor.

The position interpolator may be connected to estimate the one or more positions of the rotor taking into account the acceleration of the rotor. This tends to lead to faster transient response, and higher efficiency during transient operations .

The position interpolator may be connected to estimate the acceleration of the motor from measurements of the speed of the rotor, to estimate the future speed of the rotor from the estimate of the acceleration and to estimate the time rotor will reach a particular position using that future speed.

The position interpolator may be arranged to take into account the acceleration of the rotor by applying a correction factor. The timings of the one or more estimated positions of the rotor may be based on an initial estimation, which is then adjusted (for example multiplied) by the correction factor. The correction factor may be read from a look-up table. The control circuit may comprise a memory module in which the look-up table is stored. The values of the correction factor in the look-up table may have been empirically obtained.

The look-up table may be responsive to a torque command and/or a rotor speed value to provide the correction factor. The look-up table may be responsive to other variables, such as the temperature of the motor and/or a battery voltage drop, to provide the correction factor.

Having a look-up table of correction factors is thought to be especially beneficial because the core implementation of the control circuit can remain the same for various different applications/rotors; only the values in the correction table need be adjusted (those values being specific to particular applications, rotor inertia, load and/or product

performances) . This enables the arrangement to be relatively flexible in terms of the scenarios it can be used in.

The control circuit may comprise a control loop connected to provide the switch controller with rotor angles, dependent on a required motor torque, at which to operate the switches, the switch controller being connected to base the determination of the timings of the switch control signals also on those angles .

The control loop may comprise:

a speed estimator connected to receive the indications of the timings of one or more positions of the rotor and to provide therefrom a rotor speed value,

a subtractor connected to receive the rotor speed value and form the difference between that and a speed command value to from a speed error value,

a loop controller connected to responsive to the speed error value to increase a torque command if the rotor speed value is less than the speed command value and to decrease the torque command if the rotor speed value is more than the speed command value, a lookup table responsive to the torque command and the rotor speed value to provide the rotor angles.

The control loop may comprise an offset corrector

connected to adjust the rotor angles from the lookup table with values allowing for an offset of the position sensor.

The present invention also provides an apparatus

comprising :

a switched reluctance motor, comprising a rotor and comprising stator coils,

a control circuit according to the invention connected to the stator coils of the motor,

a supercharger having a compressor wheel coupled to the rotor of the motor to be driven thereby.

The present invention further provides a method of controlling a switched reluctance motor, comprising:

sensing the position of the rotor of the motor, using a single sensor, to provide indications of the timings of one or more positions of the rotor per revolution of the rotor,

deriving from the indications of timings of the rotor positions indications of the timings of one or more estimated positions of the rotor between the timings indicated by the sensing, and

energising stator coils of the motor at times determined in response to the indications of the timings of the estimated positions.

The method may comprise energising stator coils of the motor at times determined in response to the indications of the timings the rotor positions.

The deriving may comprise estimating the one or more positions of the rotor based on the assumption that the rotor speed is currently constant. The estimating may be based on a measured speed of the rotor. The measured speed may be based on the indications of the timings of the rotor positions. The deriving may comprise estimating the one or more positions of the rotor taking into account the acceleration of the rotor. The estimating may comprise: estimating the

acceleration of the motor from measurements of the speed of the rotor, estimating the future speed of the rotor from the estimate of the acceleration and estimating the time rotor will reach a particular position using that future speed. The estimating may comprise: making an initial estimate of the timings of the one or more estimated positions of the rotor; and adjusting the initial estimate by applying a correction factor to thereby obtain the timings of one or more estimated positions of the rotor. The correction factor may be read from a look-up table. The correction factor may be such that initial estimate is corrected to take into account the

acceleration of the rotor.

The present invention also provides driving a compressor wheel of a supercharger with the switched reluctance motor.

Brief Description of the Drawings

Examples of the invention will now be described with reference to the accompanying drawings, of which:

FIGURES 1-4 show consecutive stages of rotation of the rotor, or phases, in the operation of a known switched

reluctance at operational speeds,

FIGURE 5 is a block circuit diagram of a first known control circuit for the motor of Figure 1 etc.,

FIGURE 6 shows a magnetic position indicator ring mounted on the motor of Figure 1 etc. as used in both a second known control circuit for the motor of Figure 1 etc. and in an example of a motor control circuit in accordance with the invention,

FIGURE 7 is a block circuit diagram of a second known control circuit for the motor of Figure 1 etc.,

FIGURE 8 is a block circuit diagram of an example of a control circuit for a motor of Figure 1 etc. in accordance with the invention,

FIGURE 9 is a block circuit diagram showing more detail of a portion of the circuit of Figure 8,

FIGURE 10 is a look-up table from a further embodiment of the invention.

Examples

Figure 8 is a block diagram of an example motor control circuit 10'' in accordance with the present invention. It has elements similar to that of the prior art circuit of Figure 7, but there are significant differences. The magnetic indicator ring 50 (Figure 6) again has eight alternately magnetised sectors, but this is sensed by only one Hall Effect sensor 57. Again this provides a pulse signal58 every time aN-S boundary of the indicator ring passes the sensor 57, which is therefore once every 90° of the rotation of the rotor, which is once per pole of the rotor.

The speed estimator 32'' has a different form. In this example, it calculates the rotor speed signal from the time between the pulses 58from the single Hall Effect sensor 57. In this example the next items on the control loop: the subtractor 36, the loop controller 38 and the lookup table 41 are as in the examples of Figures 5 and 7 and provide

accordingly the switching angles for the stator coils

required. Again as in the circuit of Figure 7 the angles 42 are adjusted by the angle offset corrector 43 using the EOL values 44. The switch controller 27'' is also arranged differently. Again it receives the offset adjusted switch angles 42'' from the angle offset corrector 43' but in this example it

cooperates with a position interpolator 59set out below.

(Because there is now only one Hall Effect sensor 57 the EOL offset values 44' applied by the angle offset corrector 43' are only the angles between each N-S boundary of the magnetic ring 50 passing the sensor 57 and a respective rotor pole passing a particular coil e.g. coil A) . A more detailed block diagram of the switch controller

27'' and the position interpolator 59 is shown in Figure 9. The position interpolator 59has a first counter timer 61, counting a clock signal 61, that is also responsive to the pulses 58 from the Hall Effect sensor 57. At each pulse of the Hall Effect sensor the count achieved by the counter timer 61 is zeroed but its value is also latched, having been divided by three by divider 62 into a target register 63 of a second counter timer 64, the counter 65 of which is also zeroed by the pulse 58 from the Hall Effect sensor 57, via OR gate 66. A comparator 67 of the second counter timer 64 provides periodic output pulses 68whenever the counter 65 equals the target register 63. So the intervals defined by the value in target register 63 are therefore one third of the time taken for the last 90° of rotation of the rotor. The pulses 68 from the second counter time 65 therefore mark the expected beginnings of three subsequent coil phases of the motor if the assumption is that the speed of the motor is constant.

A three state counter 71 counts the pulses 68 to keep track of which coil pair, AA' , BB' or CC is to be energised. It provides three outputs, respective to the coil pairs, each having a pulse having the timing of one of the pulses 68 when the respective coil is to be energised. These pulses 60 are used by the switch control unit 27'' to time the operation of the switches 21 to 26 with each pulse timing consecutively coil pairs AA' , BB' , CC ,ΑΑ' , BB' , CC and so on. The assumption of constant rotor speed is a reasonable assumption in many operating conditions where it takes many revolutions of the motor for it to accelerate significantly, since the estimate of the rotor position is revised each time the Hall Effect sensor 57pulses, which is several (i.e. in this case four) times per revolution.

Under positive acceleration of the rotor, the position interpolator 59 operates as follows. The third pulse from the second counter timer 64 after the pulse 58 from the Hall

Effect sensor would occur after the next pulse from the Hall Effect sensor, however it is suppressed by the reloading of target register 63 and zeroing of the counter65 caused by that next Hall effect pulse.

Under deceleration the third pulse from the second counter timer 64 is issued, but it will be a little ahead of the next pulse from the Hall Effect sensor. However, while the counter 65 begins to count again it is soon zeroed by the next Hall Effect sensor pulse and so the next three pulses 68 are timed relative to that. Note that the position interpolator 59 does not issue a pulse at automatically at the same time as the pulse from the Hall Effect sensor but only at periods after it. An output pulse will occur at the same time as the Hall Effect pulse if the speed of the motor is constant.

The circuit of Figure 9 is preferably provided by the microcontroller and is implemented by using its on board timers for the timer counters 61 and 64, which issue software interrupts when the counts are reached. The switch control unit 27'' uses the pulses 60 from the position interpolator as follows. The outputs 60 of three state counter 71 are respectively connected to a control logic unit 72, which immediately causes a respective timer counter 70A, 70B or 70C and to select latch into its target register the relevant offset adjusted on angle from among the angles 42'' . The relevant angle is selected by the control logic unit providing a selection signal 80 to the angle offset corrector 43' , which depends on which particular N-S boundary of the indicator ring was sensed (of which the control logic unit keeps track. (Before loading the on angle into the timer counter 72 converts the angle into a time by dividing the angle by the current speed of the rotor as indicated by the rotor speed signal to provide a time at which the rotor is expected to be at that angle. For simplicity, references below are made to loading the timer counters 70 with on, freewheel and off angles, but on each occasion they are first converted to a time by the control logic unit 72.) In reply when the counter 70 reaches the target, the control logic unit 72 receives a pulse back from the timer 70 and in response it causes the switch drivers 73 to output signals to close the switches for the respective pair of stator coils. At that time it also loads the freewheel angle to the target register of the same counter timer (without zeroing the counter) and again operates the stator coil switches for the relevant coil pair appropriately (by opening one of its switches) when the pulse is received back from the timer. Then it loads the off angle to the counter timer (without zeroing the counter) and then opens both the relevant stator coil switches when the pulse is received back from the timer.

(Alternatively the timer 70 can be utilised by first zeroing it loading the target with the on angle, then when that time is reached zeroing it and reloading the target with the difference between the freewheel angle and the on angle, and then when that time is reached zeroing it reloading the target with the difference between the off angle and the freewheel angle) . Three timers counters 70 are used in this example, and the control logic unit operates the respective coil pair when it receives a pulse from one of them. Alternatively one time can be used (because only one coil pair is operated at a time) and the control logic unit remembers, from the pulses 60, which coil pair it is operating at the current time.

In a second example, which is similar to the first, the position interpolator 59 is as follows. The assumption used by the rotor position interpolator 59 to estimate the rotor position is improved by taking into account the acceleration of the rotor. In this example the times of the most recent pulses 58 from the Hall Effect sensor 57 are recorded and the current acceleration of the rotor is estimated from that. This estimate of the acceleration is then used to estimate the timings of the rotor arriving at the three phases of the motor, which in this case are every 30°.

The acceleration is estimated by the position

interpolator 59, preferably implemented by the

microcontroller, as follows. At regular time intervals the control logic unit 72 notes the speed of the rotor, from the rotor speed signal 33, and then estimates the acceleration of the rotor as [the current rotor speed minus the previous rotor speed] divided by the time interval between them. So if the rotor speed and acceleration estimates are indexed as n, and so occur at times t n , this calculation can be written as:

Speed(n) - Speed(n - 1)

Acceleration(n) =

ot

where dt is t n -t n -i . The position then estimates the speed at the next time t n+ i as: Speed (n+1) = dt x Acceleration (n) + Speed (n) where dt = t n+ i-t n

(an exemplary value for dt is a constant of 2ms) i.e. a constant acceleration is assumed.

This speed is then used to divide the on, freewheel and off angles as in the example above.

Thus, knowing the next estimated speed, the time between coil phases AA' , BB' and CC can be estimated as:

1 * 1

Speed(n+1) rotor poles x stator phases

In a further embodiment of the invention, the acceleration is not estimated using the above-mentioned formulae. This further embodiment of the invention is identical to the first embodiment except that the position interpolator 59 is

arranged to take into account the acceleration of the rotor, by applying a correction factor 101.

The position interpolator 59 first makes an initial estimate in the same manner as described with reference to the first embodiment. Acceleration of the rotor is taken into account by multiplying this initial estimate by the correction factor 101. The correction factor 101 is obtained from a look-up tablel03 (shown in Figure 10) . To extract the

appropriate correction factor 101, the control circuit 10'' retrieves the rotor speed value (see description with

reference to the first embodiment) and a torque command

(dependent on whether the rotor speed value is less than the speed command value) . An appropriate correction factor 101 is then read off the look-up table dependent on that speed value (x-axisl05 with values of 0 -XXXX) and torque command (y-axis 107 with values of 0 - 100%) . The value of the correction factor 101 is such that the initial estimate is either maintained (correction factor = 1.00) or reduced (correction factor < 1.00) . This ensures the timing of the estimated positions of the rotor is adjusted to take into account acceleration of the rotor (which can be significant in, for example, an electric supercharger) .

The look-up table 103 is populated with values of correction factor that have been obtain empirically. For example the optimal correction factors 101 for each

combination of rotor speed and load, are obtained from

experiment/calibration of the motor. In other embodiments the empirical testing may be performed by means of a computer simulation .

Having a look-up table 103 of correction factors 101 is thought to be especially beneficial because the core

implementation of the control circuit 10' ' can remain the same for various different applications/rotors; only the values in the correction table 103 need be adjusted (those values being specific to particular applications/rotor inertia) . This enables the arrangement to be relatively flexible in terms of the scenarios it can be used in.

In another embodiment (not shown) the look-up table includes third axis in respect of the temperature of the motor. Thus, the correction factor may also be adjusted, as required, in dependence on the temperature of the motor.

Another parameter that may affect the correction factor is the battery voltage supplying the motor (which may vary while the system operates) . In another embodiment (not shown) the look ¬ up table includes a third axis in respect of the battery voltage. In the above-mentioned embodiments, the switched reluctance motor controlled by the invention may be used drive the compressor wheel of a supercharger.