The design and implementation of a harmonic current computation technique based on a modified Fourier analysis, suitable for active power fdters incorporating DSPs is presented. The proposed technique is suitable for monitoring and control of load current harmonics for real-time applications. The derivation of the basic equations based on the proposed technique and the system implementation using the Analogue Devices SHARC processor are presented. The steady state and dynamic performance of the system are evaluated for a range of loading conditions.
introduction
The problem of power system harmonics has been addressed by many publications and has acquired a great deal of importance worldwide [l-51. Various circuit topologies for active filters are available. These include the standard inverter circuit configurations [2-51, the switched capacitor systems [6-81, the lattice structures [9, 101 and the voltage regulator type arrangements [I 1, 121 . These circuits constitute the main building block in implementing appropriate active power filters. Fig. 1 shows a typical active filter incorporating the various control loops. 
Fig. 1 Generuhed hlock diugrum for uctiveJhs
The response time of any active power fdter is governed by three main factors: (i) the synthesis of the reference signal.
(ii) the overall system controller. (iii) the response time of the power circuit. The response of each of these blocks is crucial when assessing the possible delays between the change in the load current and the response of the filter. Factors (ii) and (iii) are beyond the scope of this paper and have been discussed elsewhere [2] [3] [4] [5] 121 . Here the performance of the reference current generator is discussed and analysed. Compared with previous work, the proposed approach, incorporating 
load currents
There are many existing methods of identifying current harmonics in load current for single-phase and three-phase systems. Only the techniques suitable for single-phase systems are briefly reviewed below.
Analogue methods .
This technique [3, 13, 141 uses a low-pass filter to identify the fundamental component of current, which is then subtracted from the total current to give a measure of the current harmonics. The design of the active filter has to incorporate at least a 6th-order filter to ensure a reasonable roll-off frequency. The main disadvantage with this method is that the fundamental component thus derived has magnitude and phase errors. The phase lag error normally reaches more than loo", which is unacceptable for power filter applications. A phase-lead circuit can be used, but this introduces a phase shift of 360", leading to a delay of one complete mains cycle, and is therefore not suitable for an application requiring a fast response.
Digital FFT calculations
This method [3, [15] [16] [17] is the most widely used. The FFT computation is performed by talung samples of one complete cycle (or an integral number of cycles) in order to generate the Fourier coefficients and to identify the lowfrequency components in the load current. Therefore, it is suitable for slowly varying load conditions. Although this approach is more flexible than the analogue approach, there is still an inherent time delay equivalent to at least one complete mains cycle.
The computational time required for this case is enormous since the FFT computation takes a considerable amount of time. Resolutions of 12 and 14 bits (with a dynamic range over 10 bits, at least 0.1% dynamic error and 60dB SQNR) are normally required for the high-accuracy computations of active filter harmonics. Using cheap (-$IO per unit) and slow processors , the amount Techniques for identifying current harmonics in of time required to perform this operation may increase astronomically to reach several mains cycles. Therefore, this approach is not suitable for single-phase applications with fast varying loads (within one mains cycle), such as motor controllers and arc furnaces. It is, however, suitable for systems with slowly changing harmonic pattems (within looms), such as power system harmonics in medium-and high-voltage distribution networks [l, 21.
Fictitious power compensation algorithm
This technique relies on the principle of fictitious power compensation developed previously [18] [19] [20] . Despite opposition to the theory [21-231, this principle was proven to operate properly. The system controller attempts to generate a reference current signal, which minimises the undesired components of power (fictitious power). This technique is suitable for single-phase systems. However, it involves a large amount of computation.
Other algorithms
There are many harmonic estimation techniques, and all the utilities and libraries of the mathematical techniques can be used to perform this task. DSP algorithms, which form modifications of the FFT and DFT algorithms [17] , may be used to correct the nonlinearities due to other techniques. Software implementations of signal filters as FIR or IIR filters can replace the analogue techniques outlined above. Other methods have been introduced, such as neural networks [24] , adaptive [25, 261 and adaptiveipredictive [27] estimation techniques, which are quite accurate and, of course, have a much better response.
These techniques require large amounts of computation; with the help of the state-of-the-art DSPs, they can fulfil their requirements within the specified sampling and control intervals. The computational burden on the DSP in some of these cases (neural networks and some adaptive techniques) is large, and most of the DSP time (3G250p) is spent on the harmonic computation process. Our proposed technique introduces a different approach to the problem solution, in order to reduce the amount of time needed for the harmonic computations.
3
Proposed modified sliding-window Fourier ana lysis
The proposed method employs a modified sliding-window Fourier computational approach using a SHARC-2106 1 DSP, which overcomes the drawbacks associated with currently used methods.
I Basic equations
For an arbitrary band-limited repetitive waveform x(t), with a period Tperiori, and consisting only of odd harmonics ranging from the fundamental U to (U . N,,,,,) , the Fourier series equations are given by Nn, a:,:
The above equations need to be modified in order to be used in DSP applications. Discretising the above equations at a fixed sampling interval z, arid with a total number of points NPoin, per cycle, we obtain 
The above equations are still unsuitable for the fast computation of the instantaneous current harmonics because they require the signal to start (at j = 0) from an initial fixed time. This is, however, not the case for the sliding-window Fourier analysis since the starting point is always moving to the next one, once the new sampled point is available. This yields the following two equations (note that the index j ranges from NcUrrfnf to Ncu,.,.c',It -+ Npoints -1): cos(2wj.r) .
I=N,,,, I Npoznts
The modification in this case is still insignificant due to the large amount of calculation required to synthesise each harmonic amplitude and phase. The important point i o note in this case is that the fundamental component is the only one needed in the active filtering application. This is implemented by calculating only the fundamental component and subtracting its value from the total Ioad current. In this way, it is possible to obtain the total current harmonic, which in this case does not take a large amount of calculation.
The fundamental component xl(kz) is given by
+ B1 sin(wk7) (9) where k and z are as defined above. The factors A , and B, for the sliding-window system a re
t*, 7 c m t
To obtain the instantaneous values of the desired signal in real time, the values of A , and B, have to be known at that same instant of time. This necessitates the evaluation of the summations in eqns. 10 and 11 at every sampling instant, which is still time consuming.
The better alternative would be to use the software capabilities of DSPs in handling arrays in order to implement the solution of eqns. 10 and 11 into two single-dimensional arrays. The consecutive values stored in each element of these two arrays correspond to the consecutive evaluations of the equations under the summation sign of the target equations (eqns. 10 and 1 1), respectively. The summation of all the elements of the two arrays, A , and B I , are then calculated only once during the initialisation of the system. Fig. 2 summarises the approach proposed here. At each sampling interval, the old evaluated equations (N,,,, ago), which are stored in the indexed element of the arrays, are subtracted from the total saved sums of A l and B,, respectively. The sampled and calculated values of the new sampling interval are then introduced into the positions of the old ones. They are also added to the modified values of A I and B1, respectively, to produce the desired references for the variable under consideration (nonlinear load current) using eqn. 9. The system uses the principle of circular arrays [28] to represent the sliding-window problem. The amount of computations required for each coefficient is limited to one addition, one subtraction and one multiplication operation. The overall computation time is reduced significantly, and hence the calculation can be carried out within one DSP time slot. 
Hardware and software implementation
The hardware incorporates a 40MHz, ADSP-2 1061 SHARC DSP implemented in the SHARC EZ-KIT LITE [28, 291. The basic kit incorporates a 14-bit analogue interface circuit (AIC) (AD1 847). The analogueidigital converter is used for the acquisition of the load current signal, whch is sensed using a Hall-effect current transducer. The on-board digitaUanalogue interface is used to obtain the control signal from the DSP for monitoring purposes. The DSP board also includes several interrupt inputs and flag input/outputs. The flags are used to communicate the control signals between the DSP and the synchronisation circuits; this is an external custom-built board necessary to detect the starting edges of the supply-voltage waveform for the positive and negative half-cycles. These signals are isolated from the mains using 6N137 high-speed opto-couplers and are connected to the flag inputs of the DSP board.
The software uses a floating-point resolution of 64 bits. The program is written in C and dedicated for the SHARC family of DSPs. The flow chart of the program is shown in Fig. 3 . The main role of the DSP is to calculate the harmonic content of the load current waveform. This harmonic content is then used to calculate the reference signal, which drives the active filter circuit. 
The floating-point calculations were used in this program to minimise the computational overheads. This is important for the multiplication and division operations to avoid the necessity for normalising the magnitudes of the sine and cosine components generated by the DSP. Note that the sampling frequency of the analogueldigital converter onboard the DSP card is fixed at 25kHz, which corresponds to a sampling time of 4 0~. The control and sampling sub-cycle is then limited by this value. The time taken to compute the proposed algorithm is 6 p , leaving the remaining 34 ps for the overall active filter controller.
Note that by calculating only the sine component B,, instead of both A , and B I , the system ends up acting as a compensator for current harmonics as well as fundamental reactive power; this is a major advantage of the system in terms of system flexibility.
Practical results of harmonic current synthesis
The above computations lead to the system implementation for which the following results show its effectiveness. These results are shown in Figs. 4 9 for the various waveforms that were applied to the system to test its sensitivity and error analysis. Six different waveforms were applied to the system. The results for each case are listed below and are compared to the values measured with the harmonic analyser (Voltech PMlOO), and tabulated in the Appendix (Section 8).
Purely resistive load (sinusoidal current waveforms)
The simple case of a sinusoidal current waveform applied to the sensing and harmonic current calculation circuit is shown in Fig. 4. Fig. 4a shows the supply voltage waveform with its phase relation with the load current; in ths case, ths is almost sinusoidal. The hgh-frequency noise on the signal is due to the quantisation error of the oscilloscope as well as the sampling noise, which accompanies the analogue/digital conversion process. Other sources of noise are due to the fact that the sensing of the sampled current is performed via the Hall-effect transducer which introduces additional noise. The load and supply parameters and characteristics are provided in the Appendix (Section 8). shows a very small phase lag from the current waveform, which is confirmed by the value of 5.9" provided in the Appendix (Section 8). The second waveform, presented in Fig. 4b , provides the fundamental load current component, which is in phase with the supply voltage waveform. The harmonics present in the signal are, of course, neghgible, but still exist, as is clear from the corresponding table in the Appendix (Section 8). Fig. 5 shows the overall performance of the system under the loading condition of a thyristor bridge feeding a pure resistance. Fig. 5a shows the supply voltage waveform with the load current, which is, of course, a replica of the output voltage waveform. The change of amplitude present in the voltage waveform signal is due to the voltage drop across the supply impedance. This drop is predominant in this case due to the presence of the series current measuring resistance as well as the output impedance of the autotransformer used to supply the cmuit. The supply impedance is measured to be in the range of 0.8Q
Thyristor bridge with resistive load
Figs. 5h and c show the fundamental component of the load current as well as its total harmonic content. The difference here is that the first one shows the fundamental component which is in phase with the supply voltage (i.e. compensating for both harmonics and reactive power). The second waveform is the result of 1.he calculation of both A I and B1 in the C program. The magnitudes and phase shfts present in this case show good correspondance with the expected results provided in the Appendix (Section 8).
Thyristor bridge with resistive/inductive load at minimum triggering angle
The most common case of load harmonic spectrum is, of course, the inductive load, which represents most of the industrial loads and conventional DC motor drives. The inductance value used in this case is around 180mH, whch is a reasonably high value as expected in industrial cases. The corresponding current waveform, shown here in Fig. 6a in conjunction with the supply voltage, shows the smoothing effect of the highly inductive load present on the DC side of the thyristor bridge Note that the triggering angle in this case is not exactly zero but is a minimum value of around 13", as provided by the triggering module used in this case. The result wcluld thus be a phase shift between the fundamental component representing only the harmonics (shown in Fig. 6c ) arid that incorporating both the harmonics as well as the reactive power compensation (shown in Fig. 6b) .
The phase shift of about 18", which is present between the two waveforms, constitutes a reasonable value when compared with the value of 18.3" provided in the corresponding table of the Appendix (Section 8) for the h d amental component of current. Note also that the nonperfectly flat-topped waveform results in the presence of distortions in each of the two quarter-cycles forming the positive and negative half-cycles. The harmonic components in the case of Fig. 6b (for which the fundamental current waveform is given to be in phase with the supply voltage) suffer from an unevenness of the positive and negative half-cycles rising and falling edges. This fact is correct for such type of waveforms, which confirms the accuracy of the implemented system. 
Thyristor bridge with resistivefinductive load at higher triggering angle
Similar to the above loading condition for load parameters and configuration, this case provides a different triggering angle for the load current sensed by the harmonic calculation. For the case of continuous DC side current, the waveform would simply alter by being phase-shifted, with its magnitude reduced as shown in Fig. 7a . The spikes shown at the transition points are due to the resonance effect between the snubber circuit capacitor connected across the thyristor and the supply inductance. This transient oscillation is due to the energy accompanying the step transition of current path between the two thyristor pairs. The fundamental harmonic current signal, as shown in Fig. 7c is shown to lag the supply voltage waveform by a value of 59.4", as compared to the value of 58.5" which is shown in the Appendix (Section 8). The thick traces in this case are due to the digitisation noise. Fig. 7b shows the waveform of the fundamental component whch is the result of both the compensation of the harmonics and the reactive power of the load current.
Thyristor bridge with resistive/capacitive load at minimum triggering angle
However uncommon in practice, this load configuration with a thyristor bridge is tested here for the sole purpose of providing the ability to change the wave shape and position of the pulse current, as shown below. This condition of a small triggering angle is similar, to a certain extent, to the case of a diode bridge feeding a rectifier DC-link capacitor, which is very common in AC/DC/AC inverter circuits. This same configuration with a diode bridge is mainly used for the AC interface of switched mode power supplies. This widespread application (despite the fact that the harmonic pollution accompanying it is of negligible effect due to the extremely small values of currents involved with such systems) constitutes a great danger to the power quality and continuity [7] .
The high-amplitude current pulse generated here is shown in Fig. 8a for the load current and supply voltage waveform. As is clearly seen in this case, the supply waveform is non-sinusoidal. This would not change any of the system performances, except in the case of introducing further harmonics in the load current; in this case, this would be detected by the harmonic calculation system under investigation. Figs. 8b and c show the harmonic currents and the fundamental components corresponding to the two different cases of harmonic and reactive current compensation as well as harmonic current compensation, respectively.
Thyristor bridge with resistive/capacitive load at higher triggering angle
This load configuration is not of any industrial application at all. However, it is presented here for system performance demonstration. The main important characteristic of this waveform is its pulsed current during only a small portion of each half-cycle. The high-amplitude pulse can be shifted from the mid-region of the supply cycle to the right-hand side of the half-cycle. The width of the pulse reduces when shifted to the right at higher triggering angles. This is the main reason why such current waveforms (shown in Fig. 9u ) are difficult to compensate. The reference estimator has to consider this huge amount of current before the Pructicul results of reference current esrinzatorfor thyrktor bridge with capacitive loud filter can respond to it. Note that the speed of detection of any variation in this signal is delayed by a few milliseconds since the presence of the zero current periods does not help the calculation process to predict the variation quickly enough. Similar to the above systems, the fundamental component in phase with the supply voltage and that corresponding to the harmonic elimination are as presented in Figs. 9b and c, respectively. Note that the phase shift of 54.6" for the case of the total fundamental current component corresponds to a phase shift of about 54" in the estimated fundamental signal, which is acceptable under this severe loading condition. The supply voltage in Fig. 9a changes magnitude abruptly at the starting point of the capacitor charging process. This huge drop is because the current rate of rise is very high which interacts with the supply impedance.
Static and dynamic response
The proposed reference signal estimator is then used in conjunction with the other system signals to generate the control effort that will drive the PW modulator of the filter switching circuit. It is, however, important to check the system's static accuracy for the magnitudes and the phase errors.
The calibration of the measuring system can be performed taking into account the values measured for the true magnitude of the load fundamental and those calculated by the program. To compare these values, the readings must be calibrated and referred to directly directly in amps. This is performed using the case of a purely resistive load in conjunction with a sinusoidal waveform. The measured value of the fundamental component generated by the DSP (generated in volts) (0.8V from Fig. 4b ) is used in conjunction with the magnitude measured with the harmonic analyser for the true value of the fundamental load current (from the table in the Appendix (Section 8): 9.35 x cos(-5.9") = 9.3A). If the latter is divided by the former, this results in the constant transformation value of const = 9.3/0.8 = 11.625 amps/peak volts This value is then used to generate Table 1 from the data of Figs. 4-9. From this Table, it can be deduced that the percentage error does not exceed 0.925%, which is a good acceptable value for a system static accuracy.
The measurements of the phase angle errors are performed in Table 2 . The depicted error values show that the maximum error occurs with a percentage error of 8.47%, which is very high. However, if the absolute error value of 0.5" is considered to be equivalent to a time difference of 27.77p, these small absolute error values can be ignored. The system in this case must then tolerate an error of double the magnitude of the sampling interval, which is in the order of 1.44' . It is obvious from the presented cases that the system has a maximum value of the error in the order of 0.9", which is well within the tolerance band. The above error analysis perfixmed for the calculations shows a good performance, which identifies a good accuracy characteristic for the proposed system. It now remains to analyse the performance of thlz system from the dynamic performance viewpoint. The system in this case whle performing a one-cycle integration is expected to have a tracking error with a maximum of one whole cycle for zero estimation error. However, tb: practical case is much milder.
Consider the proposed system with a fast changing load, as given in Figs. 10 and 11. The various cases outlined show that the performance of the system is rather satisfactory and that the error reduces quickly with time. For cases like those in Fig. 10 , which have a step change in the load magnitude either increasing (Fig. 10a near zero crossing and Fig. 10b near the peak) or decreasing ( Fig. lo(:) , this affects the computation process. Note from the curves that the maximum error occurs for a graph like Fig. 106 (where the load current changes near the peak value of the sinusoidal waveform). This is the severest case, and a reasonable error value of the order of 10%) can be obtained within less than one half-cycle. Fig. 11 shows a slowly varying resistive load connected across a rectifying bridge with a reservoir capacitor on the DC side. Part of the resistance is being switched out of the circuit (reducing the load current). The current decay is not The implementation of the proposed technique on the SHARC processor shows a great deal of flexibility and a major reduction in computation time over ordinary techniques using standard FFT and DFT algorithms. It is well suited to the active filter application. If properly implemented even on slow and cheap platforms (such as the DSP kit used), it can serve as a fast method for generation of harmonic signals necessary for active power filter operation. The proposed harmonic estimator starts reacting to load changes after a maximum of S o p , which includes the acquisation time (analogue/digital conversion delay) as well as the computation time. The dynamic response of the system is limited only by the averaging process, which is represented here by the integration necessary for the calculation of the Fourier coefficients. Practical results show that a maximum error of 10% can be reached withm only one half-cycle. The numerous test results show that the system is robust and accurate for a range of test waveforms. Furthermore, comparing this case with the ordinary slow FFT and DFT algorithms, the proposed system is superior owing to its ability to incorporate a larger number of samples per cycle according to the hardware capabilities of the processor (memory and computational speed) as well as the data acquisition system (analogue/digital acquisition and conversion), without degrading any of the system characteristics. A larger number of points can then be used to reduce the effect of noise using numerical manipulation techniques, such as averaging of several consecutive points or oversampling. 
