AN540 - Implementacion de Filtros IIR Con Pic PDF
AN540 - Implementacion de Filtros IIR Con Pic PDF
AN540 - Implementacion de Filtros IIR Con Pic PDF
THEORY OF OPERATION
Digital lters in most cases assume the following form of relationship between the output and input sequences.
INTRODUCTION
This application note describes the implementation of various digital lters using the PIC17C42, the rst member of Microchips 2nd generation of 8-bit microcontrollers. The PIC17C42 is a very high speed 8-bit microcontroller with an instruction cycle time of 250 ns (@ 16 MHz input clock). Even though the PIC17C42 is an 8-bit device, its high speed and efcient instruction set allows implementation of digital lters for practical applications. Traditionally digital lters have been implemented using expensive Digital Signal Processors (DSPs). In a system the DSP is normally a slave processor being controlled by either an 8-bit or 16-bit microcontroller. Where sampling rates are not high (especially in mechanical control systems), a single chip solution is possible using the PIC17C42. This application note provides a few examples of implementing digital lters. Example code for 2nd order Innite Impulse Response (IIR) lters is given. The following type of lters are implemented: Low Pass High Pass Band Pass Band Stop (notch) lter
y( n) =
i=o
ai y ( n i ) +
j=o
b j x( n j)
The above equation basically states that the present output is a weighted sum of the past inputs and past outputs. In case of FIR lters, the weighted constants ai = 0 and in case of IIR lters, at least one of the ai constants is non zero. In case of IIR, the above formula may be rewritten in terms of Z transform as:
bkZ
This application note does not explain how to design a lter. Filter design theory is well established and is beyond the scope of this application note. It is assumed that a lter is designed according to the desired specications. The desired digital lters may be designed using either standard techniques or using commonly available digital lter design software packages. Finite Impulse Response (FIR) lters have many advantages over IIR lters, but are much more resource intensive (both in terms of execution time and RAM). On the other hand, IIR lters are quite attractive for implementing with the PIC17C42 resources. Especially where phase information is not so important, IIR lters are a good choice (FIR lters have a linear phase response). Of the various forms used for realizing digital lters (like, Direct form, Direct II form, Cascade form, Parallel, Lattice structure, etc.) the Direct II form is used in this application note. It is easy to understand and simple macros can be built using these structures.
The above equation can further be rewritten in difference equation format as follows:
y( n ) =
i=1
ai y ( n i ) +
j=o
b j x( n j)
DS00540C-page 1
AN540
Realization of the above equation is called the Direct Form II structure. For example, in case of a second order structure, M = N = 2, gives the following difference equations: multiplier routine is also provided. This routine is implemented as a straight line code for speed considerations. The 4th order IIR lter implemented is a Low Pass Filter with the specications shown in Table 1.
EQUATION 1: d ( n ) = x ( n ) + a1 d ( n 1 ) + a2 d ( n 2 ) EQUATION 2: y ( n ) = b0 d ( n ) + b1 d ( n 1 ) + b2 ( d ( n 2 ) )
The above difference equations may be represented as shown in Figure 1.
FIGURE 1:
X(n)
b1
-a1
The Low Pass Filter is designed using a digital lter design package (DFDP by Atlanta Signal Processors Inc.). The lter package produces lter constants of the structure shown in Table 1. Table 2 shows the lter co-efcients that are obtained for the above Low Pass lter specication.
b2
Z-1
-a2
The structure as shown in Figure 1 may be cascaded to attain a higher order lter. For example, if two stages are cascaded together, a 4th Order IIR Filter is obtained. This way, the output of the 1st stage becomes the input to the second stage. Multiple order lters are thus implemented by cascading a 2nd order lter structure as shown in Figure 1.
a2
0.167145 0.765900
b0
0.285431 0.698273
b1
0.462921 0.499908
b2
0.285431 0.698273
1 2
IMPLEMENTATION
A 4th order IIR Filter is implemented by cascading two of the structures shown in Figure 1. The output Y (output of each lter stage) is computed by direct implementation of Equation 1 and Equation 2. Since each stage is similar algorithmically, it is implemented as a macro using Microchips, Assembler/Linker for PIC17C42. This Macro (labelled BIQUAD) is called twice for implementing a 4th order lter. The output of the 1st stage is directly fed to the input of the second stage without any scaling. Scaling may be required depending on the particular application. The user can modify the code very easily without any penalty on speed. Also, saturation arithmetic is not used. Overows can be avoided by limiting the input sequence amplitude. All numbers are assumed to be 16 bits in Q15 format (15 decimal points, MSb is sign bit). Thus the user must scale and sign extend the input sequence accordingly. For example, if the input is from a 12-bit A/D converter, the user must sign extend the 12-bit input if bit 11 is a one. The BIQUAD macro is a generic macro and can be used for all IIR lters whether it is Low Pass, High Pass, Band Pass or Band Stop. A general purpose 16x16
The above lter co-efcients (5 per stage) are quantized to Q15 format (i.e they are multiplied by 32768) and saved in program memory (starting at label _coeff_lpass). The constants for both the stages are read into data memory using TLRD and TABLRD instructions in the Initialization Routine (labelled initFilter). The user may read the coefficients of only one stage at a time and save some RAM at the expense of speed. The sample 4th order Low Pass IIR Filter is tested by analyzing the impulse response of the lter. An impulse signal is fed as input to the lter. This is simulated by forcing the input to the lter by a large quantity (say 7F00h) on the rst input sample, and the all zeros from the 2nd sample onwards. The output sequence is the lters impulse response and is captured into the PICMASTERs (Microchips Universal In-Circuit Emulator) real-time trace buffer. This captured data from PICMASTER is saved to le and analyzed. Analysis was done using MathCad for Windows and a DSP Analysis program from Burr-Brown (DSPLAY). The Fourier Transform of this impulse response of the lter should display the lters frequency response, in this case being a Low Pass type. The plots of the impulse response and the frequency response are shown in Figure 2, Figure 3 and Figure 4.
MathCad is a trademark of MathSoft, Inc. DSPLAY is a trademark of Burr-Brown DFDP is a trademark of Atlanta Signal Processing Inc. Windows is a registered trademark of Microsoft Corporation.
DS00540C-page 2
AN540
FIGURE 2: IMPULSE RESPONSE CAPTURED FROM PICMASTER
Impulse Response 8000 -6000 -4000 -Magnitude 2000 -0 --2000 --4000 -Time *0.5 (mSec) | 8 | 16 | 24 | 32 | | | 56
PERFORMANCE
The resource requirements for lter implementations using a PIC17C42 is given in Table 3. These numbers can be used to determine whether a higher order lter can be executed in real-time. The same information may be used to determine the highest sampling rate possible.
FILTER APPLICATIONS
40 48 Digital lters nd applications in many areas especially those involving processing of real world signals. In some applications like ABS systems in an automobile, digital ltering becomes a must. In this case elimination of noise (especially glitches and false readings of sensors) is very critical and thus becomes a requirement of digital signal processing.
FIGURE 3:
Program Memory (locations)(1) #of Filter Stages*68 + 290 RAM (File Registers) #of Filter Stages*16 + 16
300 -200 -100 -0 -0 64 128 192 256 320 384 448 512
FIGURE 4:
Digital lters are also needed in Process Control where notch lters and low pass lters are desired because the signals from sensors are transmitted over long lines, especially in a very noisy environment. In these cases, typically a notch lter (centering 50 Hz or 60 Hz) is used. In cases of eliminating background noise, a band stop lter (e.g., 40 Hz to 120 Hz) is used. The sample code given in this application note can be used to design a feedback control system's digital compensator. For example, a typical DC Motor's digital compensator (like a dead-beat compensator) is of second order and has the same lter structure that is implemented in this application note.
DS00540C-page 3
AN540
TABLE 4: RESOURCE REQUIREMENTS
Filter Order 2 4 6 8 10 Cycles 791 1566 2341 3116 3891 Real Time (@16 MHz) 197.75 s 391.5 s 585.25 s 779.0 s 972.75 s Maximum Sampling 5.05 kHz 2.55 kHz 1.7 kHz 1.28 kHz 1.0 kHz Program Memory(1) 358 426 494 562 630 RAM 32 48 64 80 94
DS00540C-page 4
AN540
Please check the Microchip BBS for the latest version of the source code. Microchips Worldwide Web Address: www.microchip.com; Bulletin Board Support: MCHIPBBS using CompuServe (CompuServe membership not required).
APPENDIX A: IIR.LS0T
MPASM 01.40 Released IIR.ASM 1-16-1997 14:48:37 PAGE 1
LOC OBJECT CODE VALUE 00001 00002 00003 00004 00005 00001 00002 00264 00006 00007 00008 00009 00010 00011 00012 00013 00014 00015 00016 00017 00018 00019 00020 00945 00021 00022 00001 00002 00003 00004 00005 00006 00007 00008 00009 00010 00011 00012 00013 00014 00015 00016 00017 00018 00019 00020 00021 00022 00023 00024 00025 00026 00027 00028
TITLE LIST
#include <p17c42.inc> LIST ;P17C42.INC Standard Header File, Version 1.03 Microchip Technology, Inc. LIST #define #define #define #define true false TRUE FALSE 1 0 1 0 0 7
#define LSB #define MSB _INC _NO_INC _LOW _HIGH equ equ equ equ 1 0 0 1
#include <17c42.mac> LIST #include <17c42iir.mac> LIST ;******************************************************************* ; PIC17C42 MACRO ; ;Macro For A Bi-Quad IIR Filter ; 2nd order Direct Form (Transposed) Type ; ; Filter co-efficients B0 & B2 are assumed equal ; ; The difference equations for each cascade section is given by : ; Y(n) = B0*D(n) + B1*D(n-1) + B2*D(n-2) ; D(n) = X(n) - A1*D(n-1) - A2*D(n-2) ; where X(n) = input sample, Y(n) = output of filter ; and A1, A2, B0, B1, B2 are the Filter Co-efficients ; ; The above difference equations are only for 1 section of a ; 2nd order Direct_Form II Filter structure (IIR) ; ; NOTE : ; It is possible to design the above structures ; such that the co-efficients B0 = B2. If this is the ; case, ; Y(n) = B0*[D(n) + D(n-2)] = B2*[D(n) + D(n-2)] ; This way, one multiplication can be avoided ; ; If a 4th order filter is to be implemented, the output of ; the 1st structure should be input to the 2nd cascade section ;
DS00540C-page 5
AN540
00029 00030 00031 00032 00033 00034 00035 00036 00037 00038 00039 00040 00041 00042 00043 00044 00045 00046 00047 00048 00049 00050 00051 00052 00053 00054 00055 00056 00057 00058 00059 00060 00061 00062 00063 00064 00065 00066 00067 00068 00069 00070 00071 00072 00073 00074 00075 00076 00077 00078 00079 00080 00081 00082 00083 00084 00085 00086 00087 00088 00089 00090 00091 00092 00093 00094 ; Timing (WORST CASE) : ; 59+4*179 = 775 Cycles ; (194 uS @ 16 Mhz) ; Program Memory : ; 63 locations ; ;******************************************************************* ; The sample filters are designed so that B0=B2 ; This saves 1 multiplication ; B0_EQUALS_B2 equ TRUE ; ;******************************************************************* ; Parameters to BIQUAD Macro : ; Filter Constants A1, A2, B0, B1, B2 ; & D(n), D(n-1), D(n-2), filter stage # ; BIQUAD MACRO Ax1,Ax2,Bx0,Bx1,Dn,Dn_1,Dn_2,stage ; ; Compute Ax2*D(n-2) ; MOVFP16 Dn_2,AARG ; D(n-2) = multiplier MOVFP16 Ax2,BARG ; A2 = multiplicand call DblMult ; (ACCd,ACCc) = A2*D(n-2) ; ; Add product to output of 1st section ; Save result in 32 bit Accumulator ; ADD32 DPX,ACC ; ; Compute A1*D(n-1) ; MOVFP16 Dn_1,AARG ; AARG = D(n-2) = multiplier MOVFP16 Ax1,BARG ; BARG = A2 = multiplicand call DblMult ; (ACCd,ACCc) = A1*D(n-1) ; ; Compute A1*D(n-1) + A2*D(n-2) + output of previous section ; multiplications already done, so simply perform a 32 bit add ; of previously obtained multiplication results ; ADD32 DPX,ACC ; ACC = A1*D(n-1) + A2*D(n-2) + (output of 1st section) ; ; ; save the upper 16 bits of D(n) from the 32 bit accumulator ; left shift the result by 1, to adjust the decimal point after ; a Q15*Q15 multiplication ; rlcf ACC+B1,w rlcf ACC+B2,w movwf Dn rlcf ACC+B3,w ; decimal adjust ( mult by 2) movwf Dn+B1 ; ; Compute B2 * [D(n) + D(n-2)] ; #if B0_EQUALS_B2 ADD16ACC Dn_2,Dn,AARG ; AARG = Dn + D(n-2) = multiplier Bx0,BARG ; BARG = A2 = multiplicand call DblMult ; (ACCd,ACCc) = B2*[D(n)+D(n-2)] MOVPF32 DPX,ACC MOVFP16 #else MOVFP16 Bx0,BARG
00000001
DS00540C-page 6
AN540
00095 00096 00097 00098 00099 00100 00101 00102 00103 00104 00105 00106 00107 00108 00109 00110 00111 00112 00113 00114 00115 00116 00117 00118 00119 00120 00121 00122 00123 00124 00125 00126 00127 00128 00129 00130 00131 00132 00023 00024 00025 00026 00027 00028 00029 00030 00031 00032 00033 00034 00035 00036 00037 00038 00039 00040 00041 00042 00043 00044 00045 00046 00047 00048 00049 00050 MOVFP16 call MOVPF32 MOVFP16 MOVFP16 DPX,ACC Bx2,BARG Dn_2,AARG call DblMult ADD32 DPX,ACC Dn,AARG DblMult ; B0*D(n)
; B2*D(n-2)
#endif ; ; Shift down D(n-1) to D(n-2) after D(n-2) usage is no longer required. ; This way in the next iteration D(n-2) is equal to the present D(n-1) ; movfp Dn_1,AARG+B0 movpf AARG+B0,Dn_2 ; Shift down D(n-1) movfp Dn_1+B1,AARG+B1 movpf AARG+B1,Dn_2+B1 ; AARG = D(n-1) = multiplier MOVFP16 Bx1,BARG ; BARG = B1 = multiplicand
call DblMult ; (ACCd,ACCc) = B1*D(n-1) ; ; Compute Output Y = B1*D(n-1) + B2*D(n-2) + B0*D(n) ; = B1*D(n-1) + B0*[D(n) + D(n-2)] ; Since all multiplications are already done, simply perform a ; 32 bit addition ; ADD32 DPX,ACC ; ACC = B1*D(n-1) + B2*D(n-2) + B0*D(n) ; ; Shift down D(n) to D(n-1) so that in the next iteration, the new ; D(n-1) is the present D(n) ; MOV16 Dn,Dn_1 ; Shift down D(n) to D(n-1) ; ENDM LIST ; ;******************************************************************* ; Second Order Direct Form IIR Filter ; ; ; In the code given below, a 4th order IIR Elliptic Lowpass Filter ; is implemented. Other order filters may be implemented by ; taking the following example code as a basis. ; ; ; Program: IIR.ASM ; Revision Date: ; 1-13-97 Compatibility with MPASMWIN 1.40 ; ;******************************************************************* ; ; The specifications of the filter are : ; ; Sampling Frequency = 2.0 Khz ; ; Filter Type = 4th Order Elliptic Lowpass Filter ; ; Band1 Band2 ; Lower Band Edge 0.0 600 Hz ; Upper Band Edge 500 Hz 1 Khz ; Nominal Gain 1.0 0.0 ; Nominal Ripple 0.01 0.05 ;Maximum Ripple 0.00906 0.04601
DS00540C-page 7
AN540
00051 00052 00053 00054 00055 00056 00057 00058 00059 00060 00061 00062 00063 00064 00065 00066 00067 00068 00069 00070 00071 00072 00073 00074 00075 00076 00077 00078 00079 00080 00081 00082 00083 00084 00085 00086 00087 00088 00089 00090 00091 00092 00093 00094 00095 00096 00097 00098 00099 00100 00101 00102 00103 00104 00105 00106 00107 00108 00109 00110 00111 00112 00113 00114 00115 00116 ; Ripple in dB 0.07830 -26.75 ; ; The Filter Co-efficients for the above specifications ; of the filter are computed as follows : ; ; 1st Section : ; A11 = -0.133331 ; A12 = 0.167145 ; B10 = 0.285431 ; B11 = 0.462921 ; B12 = 0.285431 ; 2nd Section ; A21 = 0.147827 ; A22 = 0.765900 ; B20 = 0.698273 ; B21 = 0.499908 ; B22 = 0.698273 ; ; ; Performance (WORST Case): ; ; Cycles = #of Filter Stages*775 + 16 ; = 2*775+16 = 1566 Cycles ; ( 391 uSec) ; per each sample. Initialization ; time after reset is not counted ; Timing measured with B0_EQUALS_B2 ; set to TRUE (see BIQUAD Macro for ; explanation) ; ; Program Memory : ; = 16+ # of FilterStages * (BIQUAD Memory ; + filter co-efficients) ; + multiplier ; = 16+2*(63+5)+274 = 421 locations ; (excluding initialization) ; ; RAM usage = 48 file registers ; RAM usage/each additional stage = 16 file regs ; ; ; This time is less than 2 Khz (500 uSec), ; which means real time filtering is possible ; ;******************************************************************* ;******************************************************************* ; ; CBLOCK 0 BB0,BB1,BB2,BB3 ENDC ;******************************************************************* ; CBLOCK 0x18 DPX,DPX1,DPX2,DPX3 ; arithmetic accumulator AARG,AARG1,BARG,BARG1 ; multiply arguments ENDC ; CBLOCK Dn1, Dn1_Hi Dn1_1, Dn1_1_Hi Dn1_2, Dn1_2_Hi Dn2, Dn2_Hi Dn2_1, Dn2_1_Hi
00000000
00000018 0000001C
DS00540C-page 8
AN540
0000002A 00117 00118 00119 00120 00121 00122 00123 00124 00125 00126 00127 00128 00129 00130 00131 00132 00133 00134 00135 00136 00137 00138 00139 00140 00141 00142 00143 00144 00145 00146 00147 00148 00149 00150 00151 00152 00153 00154 00155 00156 00157 00158 00159 00160 00161 00162 00163 00164 00165 00166 00167 00168 00169 00170 00171 00172 00173 00174 00175 00176 00177 00178 00179 00180 00181 00182 Dn2_2, Dn2_2_Hi ENDC CBLOCK A11, A12, B10, B11, B12, A21, A22, B20, B21, B22, ENDC CBLOCK X, X1 Y, Y1 ; 16 bits of input stream ; 16 bits of filter output A11_Hi A12_Hi B10_Hi B11_Hi B12_Hi A21_Hi A22_Hi B20_Hi B21_Hi B22_Hi
0000002C 0000002E 00000030 00000032 00000034 00000036 00000038 0000003A 0000003C 0000003E
ACC, ACC1, ACC2, ACC3 ; 32 bit accumulator for computations ENDC ; FltStage .set 2 NumCoeff equ (5*FltStage) ; 5 Co-eff per stage ; F equ 1 ; LPASS .set TRUE HPASS .set FALSE BPASS .set FALSE ; select the desired filter type BSTOP .set FALSE ; SIGNED equ TRUE ; Set This To TRUE for signed ; ; multiplication and FALSE for unsigned. ; ;******************************************************************* ; Test Program For Low Pass Filter ;******************************************************************* ORG ; start call movlw movwf movlw movwf initFilter 0x00 X 0x7f X+BB1 0x0000
0000 0000 0000 0001 0002 0003 0004 0005 0005 0006 0007 0007 0008 0009 000A 000B
000C C00C
000D
; NextPoint call IIR_Filter tlwt _LOW,Y tracePoint tablwt _HIGH,0,Y+BB1 nop clrf X, F ; set X(n) = 0 , n <> 0 clrf X+BB1, F ; for simulating an Impulse goto NextPoint ; self goto self ; ;******************************************************************* ; initFilter ;
DS00540C-page 9
AN540
00183 00184 00185 00186 00187 00188 00189 00190 00191 00192 00193 00194 00195 00196 00197 00198 00199 00200 00201 00202 00203 00204 00205 00206 00207 00208 00209 00210 00211 00212 00213 00214 00215 00216 00217 00218 00219 00220 00221 00222 00223 00224 00225 00226 00227 00228 00229 00230 00231 00232 00233 00234 00235 00236 00237 00238 00239 00240 00241 00242 00243 00244 00245 00246 00247 00248 ; ; At first read the Filter Co-efficients from Prog. Mem to Data RAM #if LPASS movlw movwf movlw movwf HPASS movlw movwf movlw movwf BPASS movlw movwf movlw movwf BSTOP movlw movwf movlw movwf
#endif #if
#endif #if
#endif #if
0021 0002
0022
; auto increment ; ; Read Filter Co-efficients from Program Memory ; movlw NumCoeff tablrd _LOW,_INC,A11 ; garbage NextCoeff tlrd _LOW,INDF0 tablrd _HIGH,_INC,INDF0 decfsz WREG, F goto NextCoeff ; ; Initialize Dns to zero ; movlw Dn1 movwf FSR0 movlw 6*FltStage NextClr clrf INDF0, F decfsz WREG, F goto NextClr ; return ; ;******************************************************************* ; 1st Cascade Section ;******************************************************************* ; IIR_Filter ; ; Compute D(n) = X(n) + A1*D(n-1) + A2*D(n-2) ; Since the filter constants are computated in Q15 format, ; X(n) must be multiplied by 2**15 and then added to the ; other terms. ;
DS00540C-page 10
AN540
0022 0023 0024 0025 0026 0027 0028 0029 002A 002B 8804 1941 1940 290A 190A 0145 6A40 0146 6A41 0147 00249 00250 00251 00252 00253 00254 00255 00256 00257 00258 00259 00260 00261 00262 00263 00264 M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M ; Move Input to accumulator after proper scaling ; bcf ALUSTA,C rrcf X+BB1, F rrcf X, F clrf WREG, F ; Scale the input X rrcf WREG, F movwf ACC+BB1 movfp X,WREG movwf ACC+BB2 movfp X+BB1,WREG movwf ACC+BB3 ; ACC = scaled input : X*(2**15) ; ; 1st Biquad filter section ; BIQUAD A11,A12,B10,B11,Dn1,Dn1_1,Dn1_2,1 ; ; Compute Ax2*D(n-2) ; MOVFP16 Dn1_2,AARG MOVFP MOVFP
; D(n-2) = multiplier
Dn1_2+B0,AARG+B0 ; move A(B0) to B(B0) Dn1_2+B1,AARG+B1 ; move A(B1) to B(B1) ; A2 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1)
call DblMult ; (ACCd,ACCc) = A2*D(n-2) ; ; Add product to output of 1st section ; Save result in 32 bit Accumulator ; ADD32 DPX,ACC MOVFP ADDWF MOVFP ADDWFC MOVFP ADDWFC MOVFP ADDWFC ; ; ; DPX+B0,WREG ACC+B0, F DPX+B1,WREG ACC+B1, F DPX+B2,WREG ACC+B2, F DPX+B3,WREG ACC+B3, F ; ; ; ; ; ; ; ; get add get add get add get add lowest byte lowest byte 2nd byte of 2nd byte of 3rd byte of 3rd byte of 4th byte of 4th byte of of a into w of b, save in b(B0) a into w b, save in b(B1) a into w b, save in b(B2) a into w b, save in b(B3)
Compute A1*D(n-1) MOVFP16 MOVFP MOVFP MOVFP16 MOVFP MOVFP Dn1_1,AARG Dn1_1+B0,AARG+B0 Dn1_1+B1,AARG+B1 A11,BARG A11+B0,BARG+B0 A11+B1,BARG+B1 ; AARG = D(n-2) = multiplier ; move A(B0) to B(B0) ; move A(B1) to B(B1) ; BARG = A2 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1)
call DblMult ; (ACCd,ACCc) = A1*D(n-1) ; ; Compute A1*D(n-1) + A2*D(n-2) + output of previous section ; multiplications already done, so simply perform a 32 bit add ; of previously obtained multiplication results ; ADD32 DPX,ACC ; ACC = A1*D(n-1) + A2*D(n-2) +
DS00540C-page 11
AN540
003E 003F 0040 0041 0042 0043 0044 0045 6A18 0F44 6A19 1145 6A1A 1146 6A1B 1147 M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M MOVFP ADDWF MOVFP ADDWFC MOVFP ADDWFC MOVFP ADDWFC DPX+B0,WREG ACC+B0, F DPX+B1,WREG ACC+B1, F DPX+B2,WREG ACC+B2, F DPX+B3,WREG ACC+B3, F ; ; ; ; ; ; ; ; ; get add get add get add get add (output of 1st section) lowest byte of a into w lowest byte of b, save in b(B0) 2nd byte of a into w 2nd byte of b, save in b(B1) 3rd byte of a into w 3rd byte of b, save in b(B2) 4th byte of a into w 4th byte of b, save in b(B3)
; ; ; save the upper 16 bits of D(n) from the 32 bit accumulator ; left shift the result by 1, to adjust the decimal point after ; a Q15*Q15 multiplication ; rlcf ACC+B1,w rlcf ACC+B2,w movwf Dn1 rlcf ACC+B3,w ; decimal adjust ( mult by 2) movwf Dn1+B1 ; ; Compute B2 * [D(n) + D(n-2)] ; #if B0_EQUALS_B2 ADD16ACC movfp addwf movwf movfp addwfc movwf MOVFP16 MOVFP MOVFP Dn1_2,Dn1,AARG Dn1_2+B0,WREG Dn1+B0,w AARG+B0 Dn1_2+B1,WREG Dn1+B1,w AARG+B1 B10,BARG B10+B0,BARG+B0 B10+B1,BARG+B1 ; BARG = A2 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1) ; (ACCd,ACCc) = B2*[D(n)+D(n-2)] ; AARG = Dn + D(n-2) = multiplier
call DblMult MOVPF32 DPX,ACC MOVPF MOVPF MOVPF MOVPF DPX+B0,ACC+B0 DPX+B1,ACC+B1 DPX+B2,ACC+B2 DPX+B3,ACC+B3
; ; ; ;
to to to to
#else MOVFP16 MOVFP16 call MOVPF32 MOVFP16 MOVFP16 call ADD32 B10,BARG Dn1,AARG DblMult DPX,ACC Bx2,BARG Dn1_2,AARG DblMult DPX,ACC
; B0*D(n)
; B2*D(n-2)
#endif ; ; Shift down D(n-1) to D(n-2) after D(n-2) usage is no longer required. ; This way in the next iteration D(n-2) is equal to the present D(n-1) ;
DS00540C-page 12
AN540
0058 0059 005A 005B 7C22 5C24 7D23 5D25 M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M 00265 00266 00267 00268 M M M M M M M M M M M M M M M M M M M M M movfp movpf movfp movpf MOVFP16 MOVFP MOVFP Dn1_1,AARG+B0 AARG+B0,Dn1_2 Dn1_1+B1,AARG+B1 AARG+B1,Dn1_2+B1 B11,BARG B11+B0,BARG+B0 B11+B1,BARG+B1 ; Shift down D(n-1) ; AARG = D(n-1) = multiplier ; BARG = B1 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1)
005E E0AF
call DblMult ; (ACCd,ACCc) = B1*D(n-1) ; ; Compute Output Y = B1*D(n-1) + B2*D(n-2) + B0*D(n) ; = B1*D(n-1) + B0*[D(n) + D(n-2)] ; Since all multiplications are already done, simply perform a ; 32 bit addition ; ADD32 DPX,ACC ; ACC = B1*D(n-1) + B2*D(n-2) + B0*D(n) MOVFP ADDWF MOVFP ADDWFC MOVFP ADDWFC MOVFP ADDWFC DPX+B0,WREG ACC+B0, F DPX+B1,WR ACC+B1, F DPX+B2,WREG ACC+B2, F DPX+B3,WREG ACC+B3, F ; ; ; ; ; ; ; ; get add get add get add get add lowest byte lowest byte 2nd byte of 2nd byte of 3rd byte of 3rd byte of 4th byte of 4th byte of of a into w of b, save in b(B0) a into w b, save in b(B1) a into w b, save in b(B2) a into w b, save in b(B3)
; ; Shift down D(n) to D(n-1) so that in the next iteration, the new ; D(n-1) is the present D(n) ; MOV16 Dn1,Dn1_1 ; Shift down D(n) to D(n-1) MOVFP MOVWF MOVFP MOVWF Dn1+B0,WREG Dn1_1+B0 Dn1+B1,WREG Dn1_1+B1 ; ; ; ; get byte of a into w move to b(B0) get byte of a into w move to b(B1)
; ; ; 2nd Biquad filter section ; BIQUAD A21,A22,B20,B21,Dn2,Dn2_1,Dn2_2,2 ; ; Compute Ax2*D(n-2) ; MOVFP16 Dn2_2,AARG MOVFP MOVFP MOVFP16 MOVFP MOVFP Dn2_2+B0,AARG+B0 Dn2_2+B1,AARG+B1 A22,BARG A22+B0,BARG+B0 A22+B1,BARG+B1
; D(n-2) = multiplier ; move A(B0) to B(B0) ; move A(B1) to B(B1) ; A2 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1)
call DblMult ; (ACCd,ACCc) = A2*D(n-2) ; ; Add product to output of 1st section ; Save result in 32 bit Accumulator ; ADD32 DPX,ACC
DS00540C-page 13
AN540
0070 0071 0072 0073 0074 0075 0076 0077 6A18 0F44 6A19 1145 6A1A 1146 6A1B 1147 M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M MOVFP ADDWF MOVFP ADDWFC MOVFP ADDWFC MOVFP ADDWFC ; ; ; DPX+B0,WREG ACC+B0, F DPX+B1,WREG ACC+B1, F DPX+B2,WREG ACC+B2, F DPX+B3,WREG ACC+B3, F ; ; ; ; ; ; ; ; get add get add get add get add lowest byte lowest byte 2nd byte of 2nd byte of 3rd byte of 3rd byte of 4th byte of 4th byte of of a into w of b, save in b(B0) a into w b, save in b(B1) a into w b, save in b(B2) a into w b, save in b(B3)
Compute A1*D(n-1) MOVFP16 MOVFP MOVFP MOVFP16 MOVFP MOVFP Dn2_1,AARG Dn2_1+B0,AARG+B0 Dn2_1+B1,AARG+B1 A21,BARG A21+B0,BARG+B0 A21+B1,BARG+B1 ; AARG = D(n-2) = multiplier ; move A(B0) to B(B0) ; move A(B1) to B(B1) ; BARG = A2 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1)
call DblMult ; (ACCd,ACCc) = A1*D(n-1) ; ; Compute A1*D(n-1) + A2*D(n-2) + output of previous section ; multiplications already done, so simply perform a 32 bit add ; of previously obtained multiplication results ; ADD32 DPX,ACC ; ACC = A1*D(n-1) + A2*D(n-2) + ; (output of 1st section) MOVFP DPX+B0,WREG ; get lowest byte of a into w ADDWF ACC+B0, F ; add lowest byte of b, save in b(B0) MOVFP DPX+B1,WREG ; get 2nd byte of a into w ADDWFC ACC+B1, F ; add 2nd byte of b, save in b(B1) MOVFP DPX+B2,WREG ; get 3rd byte of a into w ADDWFC ACC+B2, F ; add 3rd byte of b, save in b(B2) MOVFP DPX+B3,WREG ; get 4th byte of a into w ADDWFC ACC+B3, F ; add 4th byte of b, save in b(B3) ; ; ; save the upper 16 bits of D(n) from the 32 bit accumulator ; left shift the result by 1, to adjust the decimal point after ; a Q15*Q15 multiplication ; rlcf ACC+B1,w rlcf ACC+B2,w movwf Dn2 rlcf ACC+B3,w ; decimal adjust ( mult by 2) movwf Dn2+B1 ; ; Compute B2 * [D(n) + D(n-2)] ; #if B0_EQUALS_B2 ADD16ACC Dn2_2,Dn2,AARG movfp addwf movwf movfp addwfc movwf Dn2_2+B0,WREG Dn2+B0,w AARG+B0 Dn2_2+B1,WREG Dn2+B1,w AARG+B1 ; BARG = A2 = multiplicand ; AARG = Dn + D(n-2) = multiplier
MOVFP16 B20,BARG
DS00540C-page 14
AN540
0090 7E3A 0091 7F3B 0092 E0AF M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M M MOVFP MOVFP B20+B0,BARG+B0 B20+B1,BARG+B1 ; move A(B0) to B(B0) ; move A(B1) to B(B1) ; (ACCd,ACCc) = B2*[D(n)+D(n-2)]
call DblMult MOVPF32 DPX,ACC MOVPF MOVPF MOVPF MOVPF DPX+B0,ACC+B0 DPX+B1,ACC+B1 DPX+B2,ACC+B2 DPX+B3,ACC+B3
; ; ; ;
to to to to
#else MOVFP16 MOVFP16 call MOVPF32 MOVFP16 MOVFP16 call ADD32 B20,BARG Dn2,AARG DblMult DPX,ACC Bx2,BARG Dn2_2,AARG DblMult DPX,ACC
; B0*D(n)
; B2*D(n-2)
#endif ; ; Shift down D(n-1) to D(n-2) after D(n-2) usage is no longer required. ; This way in the next iteration D(n-2) is equal to the present D(n-1) ; movfp Dn2_1,AARG+B0 movpf AARG+B0,Dn2_2 ; Shift down D(n-1) movfp Dn2_1+B1,AARG+B1 movpf AARG+B1,Dn2_2+B1 ; AARG = D(n-1) = multiplier MOVFP16 MOVFP MOVFP B21,BARG B21+B0,BARG+B0 B21+B1,BARG+B1 ; BARG = B1 = multiplicand ; move A(B0) to B(B0) ; move A(B1) to B(B1)
009D E0AF
call DblMult ; (ACCd,ACCc) = B1*D(n-1) ; ; Compute Output Y = B1*D(n-1) + B2*D(n-2) + B0*D(n) ; = B1*D(n-1) + B0*[D(n) + D(n-2)] ; Since all multiplications are already done, simply perform a ; 32 bit addition ; ADD32 DPX,ACC ; ACC = B1*D(n-1) + B2*D(n-2) + B0*D(n) MOVFP ADDWF MOVFP ADDWFC MOVFP ADDWFC MOVFP ADDWFC DPX+B0,WREG ACC+B0, F DPX+B1,WREG ACC+B1, F DPX+B2,WREG ACC+B2, F DPX+B3,WREG ACC+B3, F ; ; ; ; ; ; ; ; get add get add get add get add lowest byte lowest byte 2nd byte of 2nd byte of 3rd byte of 3rd byte of 4th byte of 4th byte of of a into w of b, save in b(B0) a into w b, save in b(B1) a into w b, save in b(B2) a into w b, save in b(B3)
; ; Shift down D(n) to D(n-1) so that in the next iteration, the new ; D(n-1) is the present D(n) ; MOV16 Dn2,Dn2_1 ; Shift down D(n) to D(n-1) MOVFP MOVWF Dn2+B0,WREG Dn2_1+B0 ; get byte of a into w ; move to b(B0)
DS00540C-page 15
AN540
00A8 6A27 00A9 0129 M M M M 00269 00270 00271 00272 00273 00274 00275 M M M M M M 00276 00277 00278 00279 00280 00281 00282 00178 00283 00284 00285 00286 00287 00288 00289 00290 00291 00292 00293 00294 00295 00296 00297 00298 00299 00300 00301 00302 00303 00304 00305 00306 00307 00308 00309 00310 00311 00312 00313 00314 00315 00316 00317 00318 00319 00320 00321 00322 00323 MOVFP MOVWF Dn2+B1,WREG Dn2_1+B1 ; get byte of a into w ; move to b(B1)
; ; ; The filter output is now computed ; Save the Upper 16 Bits of 32 bit Accumulator into Y after ; adjusting the decimal point ; MOV16 MOVFP MOVWF MOVFP MOVWF ; return ; Output Y(n) computed ; ;******************************************************************* ; Set SIGNED/UNSIGNED Flag Before Including 17c42MPY.mac ; #include <17c42MPY.mac> LIST ;******************************************************************* ; Low Pass Filter Co-efficients ; ; ; ELLIPTIC LOWPASS FILTER ; ; FILTER ORDER = 4 ; Sampling frequency = 2.000 KiloHertz ; ; BAND 1 BAND 2 ; ; ; LOWER BAND EDGE .00000 .60000 ; UPPER BAND EDGE .50000 1.00000 ; NOMINAL GAIN 1.00000 .00000 ; NOMINAL RIPPLE .01000 .05000 ; MAXIMUM RIPPLE .00906 .04601 ; RIPPLE IN dB .07830 -26.74235 ; ; I A(I,1) A(I,2) B(I,0) B(I,1) B(I,2) ; ; 1 -.133331 .167145 .285431 .462921 .285431 ; .147827 .765900 .698273 .499908 .698273 ; _coeff_lpass data data data data data data data data data data ; co-efficients for 1st Cascade section ; -A11 ; -A12 ; B10 ; B11 ; B12 ; co-efficients for 2nd Cascade section ; -A21 ; -A22 ; B20 ; B21 ; B22 ACC+BB2,Y ACC+BB2+B0,WREG Y+B0 ACC+BB2+B1,WREG Y+B1 ; ; ; ; get byte of a into w move to b(B0) get byte of a into w move to b(B1)
00AE 0002
01C1 01C1 01C2 01C3 01C4 01C5 01C6 01C7 01C8 01C9 01CA
1111 EA9B 2489 3B41 2489 ED14 9DF7 5961 3FFD 5961
4369 -5477 9353 15169 9353 -4844 -25097 22881 16381 22881
; ;******************************************************************* ;
DS00540C-page 16
AN540
00324 00325 00326 00327 00328 00329 00330 00331 00332 00333 00334 00335 00336 00337 00338 00339 00340 00341 00342 00343 00344 00345 00346 00347 00348 00349 00350 00351 00352 00353 00354 00355 00356 00357 00358 00359 00360 00361 00362 00363 00364 00365 00366 00367 00368 00369 00370 00371 00372 00373 00374 00375 00376 00377 00378 00379 00380 00381 00382 00383 00384 00385 00386 00387 00388 00389 ; ;******************************************************************* ; High Pass Filter Co-efficients ; ; ; ELLIPTIC HIGHPASS FILTER ; ; FILTER ORDER = 4 ; Sampling frequency = 2.000 KiloHertz ; ; BAND 1 BAND 2 ; ; ; LOWER BAND EDGE .00000 .50000 ; UPPER BAND EDGE .40000 1.00000 ; NOMINAL GAIN .00000 1.00000 ; NOMINAL RIPPLE .04000 .02000 ; MAXIMUM RIPPLE .03368 .01686 ; RIPPLE IN dB -29.45335 .14526 ; ; I A(I,1) A(I,2) B(I,0) B(I,1) B(I,2) ; ; 1 .276886 .195648 .253677 -.411407 .253677 ; 2 -.094299 .780396 .678650 -.485840 .678650 ; ; _coeff_hpass ; co-efficients for 1st Cascade section data -9073 ; -A11 data -6411 ; -A12 data 8313 ; B10 data -13481 ; B11 data 8313 ; B12 ; ; co-efficients for 2nd Cascade section data 3090 ; -A21 data -25572 ; -A22 data 22238 ; B20 data -15920 ; B21 data 22238 ; B22 ; ;******************************************************************* ; ;******************************************************************* ; Band Pass Filter Co-efficients ; ; ; ELLIPTIC BANDPASS FILTER ; ; FILTER ORDER = 4 ; Sampling frequency = 2.000 KiloHertz ; ; BAND 1 BAND 2 BAND 3 ; ; ; LOWER BAND EDGE .00000 .30000 .90000 ; UPPER BAND EDGE .10000 .70000 1.00000 ; NOMINAL GAIN .00000 1.00000 .00000 ; NOMINAL RIPPLE .05000 .05000 .05000 ; MAXIMUM RIPPLE .03644 .03867 .03641 ; RIPPLE IN dB -28.76779 .32956 -28.77647 ; ; ; I A(I,1) A(I,2) B(I,0) B(I,1) B(I,2) ; ; 1 -.936676 .550568 .444000 -.865173 .444000 ; 2 .936707 .550568 .615540 1.199402 .615540 ;
01CB 01CB 01CC 01CD 01CE 01CF 01D0 01D1 01D2 01D3 01D4
DC8F E6F5 2079 CB57 2079 0C12 9C1C 56DE C1D0 56DE
DS00540C-page 17
AN540
01D5 01D5 01D6 01D7 01D8 01D9 01DA 01DB 01DC 01DD 01DE 3BF2 DCC4 1C6A C8A1 1C6A C40D DCC4 2765 4CC3 2765 00390 00391 00392 00393 00394 00395 00396 00397 00398 00399 00400 00401 00402 00403 00404 00405 00406 00407 00408 00409 00410 00411 00412 00413 00414 00415 00416 00417 00418 00419 00420 00421 00422 00423 00424 00425 00426 00427 00428 00429 00430 00431 00432 00433 00434 00435 00436 00437 00438 00439 00440 00441 00442 00443 00444 00445 00446 _coeff_bpass ; co-efficients for 1st Cascade section data 30693/2 ; -A11 data -18041/2 ; -A12 data 14549/2 ; B10 data -28350/2 ; B11 data 14549/2 ; B12 ; ; co-efficients for 2nd Cascade section data -30694/2 ; -A21 data -18041/2 ; -A22 data 20170/2 ; B20 data 39302/2 ; B21 data 20170/2 ; B22 ; ;******************************************************************* ; ;******************************************************************* ; Band Stop Filter Co-efficients ; ; ; ELLIPTIC BANDSTOP FILTER ; ; FILTER ORDER = 4 ; Sampling frequency = 2.000 KiloHertz ; ; BAND 1 BAND 2 BAND 3 ; ; ;LOWER BAND EDGE .00000 .45000 .70000 ;UPPER BAND EDGE .30000 .55000 1.00000 ;NOMINAL GAIN 1.00000 .00000 1.00000 ;NOMINAL RIPPLE .05000 .05000 .05000 ;MAXIMUM RIPPLE .03516 .03241 .03517 ;RIPPLE IN dB .30015 -29.78523 .30027 ; ; ; I A(I,1) A(I,2) B(I,0) B(I,1) B(I,2) ; ; 1 .749420 .583282 .392685 .087936 .392685 ; 2 -.749390 .583282 1.210022 -.270935 1.210022 ; _coeff_bstop ; co-efficients for 1st Cascade section data -24557/2 ; -A11 data -19113/2 ; -A12 data 12868/2 ; B10 data 2881/2 ; B11 data 12868/2 ; B12 ; co-efficients for 2nd Cascade section data 24556/2 ; -A21 data -19113/2 ; -A22 data 39650/2 ; B20 data -8878/2 ; B21 data 39650/2 ; B22 ; ;******************************************************************* END
01DF 01DF 01E0 01E1 01E2 01E3 01E4 01E5 01E6 01E7 01E8
D00A DAAC 1922 05A0 1922 2FF6 DAAC 4D71 EEA9 4D71
DS00540C-page 18
AN540
MEMORY USAGE MAP (X = Used, 0000 0040 0080 00C0 0100 0140 0180 01C0 : : : : : : : : XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX - = Unused) XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXX------XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX ---------------XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX XXXXXXXXXXXXXXXX
All other memory blocks unused. Program Memory Words Used: 489
0 0 reported, 0 reported,
0 suppressed 0 suppressed
DS00540C-page 19
Note the following details of the code protection feature on PICmicro MCUs. The PICmicro family meets the specifications contained in the Microchip Data Sheet. Microchip believes that its family of PICmicro microcontrollers is one of the most secure products of its kind on the market today, when used in the intended manner and under normal conditions. There are dishonest and possibly illegal methods used to breach the code protection feature. All of these methods, to our knowledge, require using the PICmicro microcontroller in a manner outside the operating specifications contained in the data sheet. The person doing so may be engaged in theft of intellectual property. Microchip is willing to work with the customer who is concerned about the integrity of their code. Neither Microchip nor any other semiconductor manufacturer can guarantee the security of their code. Code protection does not mean that we are guaranteeing the product as unbreakable. Code protection is constantly evolving. We at Microchip are committed to continuously improving the code protection features of our product.
If you have any further questions about this matter, please contact the local sales office nearest to you.
Information contained in this publication regarding device applications and the like is intended through suggestion only and may be superseded by updates. It is your responsibility to ensure that your application meets with your specifications. No representation or warranty is given and no liability is assumed by Microchip Technology Incorporated with respect to the accuracy or use of such information, or infringement of patents or other intellectual property rights arising from such use or otherwise. Use of Microchips products as critical components in life support systems is not authorized except with express written approval by Microchip. No licenses are conveyed, implicitly or otherwise, under any intellectual property rights.
Trademarks The Microchip name and logo, the Microchip logo, FilterLab, KEELOQ, microID, MPLAB, PIC, PICmicro, PICMASTER, PICSTART, PRO MATE, SEEVAL and The Embedded Control Solutions Company are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries. dsPIC, ECONOMONITOR, FanSense, FlexROM, fuzzyLAB, In-Circuit Serial Programming, ICSP, ICEPIC, microPort, Migratable Memory, MPASM, MPLIB, MPLINK, MPSIM, MXDEV, PICC, PICDEM, PICDEM.net, rfPIC, Select Mode and Total Endurance are trademarks of Microchip Technology Incorporated in the U.S.A. Serialized Quick Turn Programming (SQTP) is a service mark of Microchip Technology Incorporated in the U.S.A. All other trademarks mentioned herein are property of their respective companies. 2002, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.
Printed on recycled paper.
Microchip received QS-9000 quality system certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona in July 1999. The Companys quality system processes and procedures are QS-9000 compliant for its PICmicro 8-bit MCUs, KEELOQ code hopping devices, Serial EEPROMs and microperipheral products. In addition, Microchips quality system for the design and manufacture of development systems is ISO 9001 certified.
M
WORLDWIDE SALES AND SERVICE
AMERICAS
Corporate Office
2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7200 Fax: 480-792-7277 Technical Support: 480-792-7627 Web Address: http://www.microchip.com
ASIA/PACIFIC
Australia
Microchip Technology Australia Pty Ltd Suite 22, 41 Rawson Street Epping 2121, NSW Australia Tel: 61-2-9868-6733 Fax: 61-2-9868-6755
Japan
Microchip Technology Japan K.K. Benex S-1 6F 3-18-20, Shinyokohama Kohoku-Ku, Yokohama-shi Kanagawa, 222-0033, Japan Tel: 81-45-471- 6166 Fax: 81-45-471-6122
Rocky Mountain
2355 West Chandler Blvd. Chandler, AZ 85224-6199 Tel: 480-792-7966 Fax: 480-792-7456
China - Beijing
Microchip Technology Consulting (Shanghai) Co., Ltd., Beijing Liaison Office Unit 915 Bei Hai Wan Tai Bldg. No. 6 Chaoyangmen Beidajie Beijing, 100027, No. China Tel: 86-10-85282100 Fax: 86-10-85282104
Korea
Microchip Technology Korea 168-1, Youngbo Bldg. 3 Floor Samsung-Dong, Kangnam-Ku Seoul, Korea 135-882 Tel: 82-2-554-7200 Fax: 82-2-558-5934
Atlanta
500 Sugar Mill Road, Suite 200B Atlanta, GA 30350 Tel: 770-640-0034 Fax: 770-640-0307
Singapore
Microchip Technology Singapore Pte Ltd. 200 Middle Road #07-02 Prime Centre Singapore, 188980 Tel: 65-6334-8870 Fax: 65-6334-8850
Boston
2 Lan Drive, Suite 120 Westford, MA 01886 Tel: 978-692-3848 Fax: 978-692-3821
China - Chengdu
Microchip Technology Consulting (Shanghai) Co., Ltd., Chengdu Liaison Office Rm. 2401, 24th Floor, Ming Xing Financial Tower No. 88 TIDU Street Chengdu 610016, China Tel: 86-28-6766200 Fax: 86-28-6766599
Taiwan
Microchip Technology Taiwan 11F-3, No. 207 Tung Hua North Road Taipei, 105, Taiwan Tel: 886-2-2717-7175 Fax: 886-2-2545-0139
Chicago
333 Pierce Road, Suite 180 Itasca, IL 60143 Tel: 630-285-0071 Fax: 630-285-0075
Dallas
4570 Westgrove Drive, Suite 160 Addison, TX 75001 Tel: 972-818-7423 Fax: 972-818-2924
China - Fuzhou
Microchip Technology Consulting (Shanghai) Co., Ltd., Fuzhou Liaison Office Unit 28F, World Trade Plaza No. 71 Wusi Road Fuzhou 350001, China Tel: 86-591-7503506 Fax: 86-591-7503521
EUROPE
Denmark
Microchip Technology Nordic ApS Regus Business Centre Lautrup hoj 1-3 Ballerup DK-2750 Denmark Tel: 45 4420 9895 Fax: 45 4420 9910
Detroit
Tri-Atria Office Building 32255 Northwestern Highway, Suite 190 Farmington Hills, MI 48334 Tel: 248-538-2250 Fax: 248-538-2260
China - Shanghai
Microchip Technology Consulting (Shanghai) Co., Ltd. Room 701, Bldg. B Far East International Plaza No. 317 Xian Xia Road Shanghai, 200051 Tel: 86-21-6275-5700 Fax: 86-21-6275-5060
Kokomo
2767 S. Albright Road Kokomo, Indiana 46902 Tel: 765-864-8360 Fax: 765-864-8387
France
Microchip Technology SARL Parc dActivite du Moulin de Massy 43 Rue du Saule Trapu Batiment A - ler Etage 91300 Massy, France Tel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79
Los Angeles
18201 Von Karman, Suite 1090 Irvine, CA 92612 Tel: 949-263-1888 Fax: 949-263-1338
China - Shenzhen
Microchip Technology Consulting (Shanghai) Co., Ltd., Shenzhen Liaison Office Rm. 1315, 13/F, Shenzhen Kerry Centre, Renminnan Lu Shenzhen 518001, China Tel: 86-755-2350361 Fax: 86-755-2366086
New York
150 Motor Parkway, Suite 202 Hauppauge, NY 11788 Tel: 631-273-5305 Fax: 631-273-5335
Germany
Microchip Technology GmbH Gustav-Heinemann Ring 125 D-81739 Munich, Germany Tel: 49-89-627-144 0 Fax: 49-89-627-144-44
San Jose
Microchip Technology Inc. 2107 North First Street, Suite 590 San Jose, CA 95131 Tel: 408-436-7950 Fax: 408-436-7955
Hong Kong
Microchip Technology Hongkong Ltd. Unit 901-6, Tower 2, Metroplaza 223 Hing Fong Road Kwai Fong, N.T., Hong Kong Tel: 852-2401-1200 Fax: 852-2401-3431
Italy
Microchip Technology SRL Centro Direzionale Colleoni Palazzo Taurus 1 V. Le Colleoni 1 20041 Agrate Brianza Milan, Italy Tel: 39-039-65791-1 Fax: 39-039-6899883
Toronto
6285 Northam Drive, Suite 108 Mississauga, Ontario L4V 1X5, Canada Tel: 905-673-0699 Fax: 905-673-6509
India
Microchip Technology Inc. India Liaison Office Divyasree Chambers 1 Floor, Wing A (A3/A4) No. 11, OShaugnessey Road Bangalore, 560 025, India Tel: 91-80-2290061 Fax: 91-80-2290062
United Kingdom
Arizona Microchip Technology Ltd. 505 Eskdale Road Winnersh Triangle Wokingham Berkshire, England RG41 5TU Tel: 44 118 921 5869 Fax: 44-118 921-5820
03/01/02