AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the...

28
2016 Microchip Technology Inc. DS00002095B-page 1 AN2095 INTRODUCTION A Transistor Coil Ignition (TCI) type of an Inductive Discharge Ignition (IDI) system is an electronic ignition system used in internal combustion engines. An ignition system provides a high-voltage spark in each of the engine’s cylinders to ignite the air-fuel mixture. TCI uses the charge stored in an inductor to fire the spark plug. This application note briefly explains the implementation of the TCI system with integrated Remote Keyless Entry (RKE) and Immobilizer functionalities using the advanced Core Independent Peripherals (CIPs) of PIC ® microcontrollers, such as Angular Timer (AT), Signal Measurement Timer (SMT), Math Accelerator and Configurable Logic Cell (CLC). THE BASIC PRINCIPLE An IDI or TCI system builds up a charge in the primary of the ignition coil then releases it at the right moment to ignite the air-fuel mixture in the cylinder. An important feature of an TCI system is the slightly longer spark duration than in a Capacitive Discharge Ignition (CDI) system. The basic block diagram of a TCI system is shown in Figure 1. FIGURE 1: BASIC TCI BLOCK DIAGRAM The primary of the ignition coil is connected to a 12V battery and charged for a particular dwell time. The circuit is switched ON and OFF by a transistor/IGBT switch. When the switch is ON, the current from the primary windings in the ignition coil flow through the switch and it is grounded. The flow of current in the primary winding causes a magnetic field to be formed around the ignition coil’s secondary windings. When the switch is turned OFF, the current can no longer flow to ground and the magnetic field around the ignition coil’s secondary windings collapses. This causes a high-voltage current of 30,000 to 40,000 volts to be induced in the ignition coil’s secondary windings. This voltage is strong enough to jump the spark plug gap and generate the spark. Authors: Namrata Dalvi, Shailendra Vengurlekar, Ashutosh Tiwari, Carlos Ribeiro Microchip Technology Inc. MCU 12V Battery Thermistor Throttle Signal Conditioning Ignition Coil Spark Plug IGBT IGBT Gate Control Pick-up signal from pulsar coil + - Transistor Coil Ignition with Integrated Remote Keyless Entry and Immobilizer Using PIC ® Microcontrollers

Transcript of AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the...

Page 1: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095Transistor Coil Ignition with Integrated Remote Keyless Entry

and Immobilizer Using PIC® Microcontrollers

INTRODUCTION

A Transistor Coil Ignition (TCI) type of an InductiveDischarge Ignition (IDI) system is an electronic ignitionsystem used in internal combustion engines. Anignition system provides a high-voltage spark in each ofthe engine’s cylinders to ignite the air-fuel mixture. TCIuses the charge stored in an inductor to fire the sparkplug.

This application note briefly explains theimplementation of the TCI system with integratedRemote Keyless Entry (RKE) and Immobilizerfunctionalities using the advanced Core IndependentPeripherals (CIPs) of PIC® microcontrollers, such asAngular Timer (AT), Signal Measurement Timer (SMT),Math Accelerator and Configurable Logic Cell (CLC).

THE BASIC PRINCIPLE

An IDI or TCI system builds up a charge in the primaryof the ignition coil then releases it at the right momentto ignite the air-fuel mixture in the cylinder. Animportant feature of an TCI system is the slightly longerspark duration than in a Capacitive Discharge Ignition(CDI) system.

The basic block diagram of a TCI system is shown inFigure 1.

FIGURE 1: BASIC TCI BLOCK DIAGRAM

The primary of the ignition coil is connected to a 12Vbattery and charged for a particular dwell time. Thecircuit is switched ON and OFF by a transistor/IGBTswitch. When the switch is ON, the current from theprimary windings in the ignition coil flow through theswitch and it is grounded. The flow of current in theprimary winding causes a magnetic field to be formedaround the ignition coil’s secondary windings. When

the switch is turned OFF, the current can no longer flowto ground and the magnetic field around the ignitioncoil’s secondary windings collapses. This causes ahigh-voltage current of 30,000 to 40,000 volts to beinduced in the ignition coil’s secondary windings. Thisvoltage is strong enough to jump the spark plug gapand generate the spark.

Authors: Namrata Dalvi,Shailendra Vengurlekar,Ashutosh Tiwari,Carlos Ribeiro

Microchip Technology Inc.

MCU

12V Battery

ThermistorThrottle

Signal Conditioning

Ignition Coil

Spark Plug

IGBT

IGBT Gate Control

Pick-up signal from pulsar coil

+

-

2016 Microchip Technology Inc. DS00002095B-page 1

Page 2: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

DWELL TIME

Dwell is the amount of time required to charge aninductive coil to its maximum energy level. In terms ofmodern engine control, dwell is defined in milliseconds.Typical ignition coils will have a dwell time between2 ms and 5 ms. If the ignition coil is charged beyond thedwell time, it will overheat and be quickly damaged. If itis charged for a lesser duration, then it will not be ableto produce a sufficient amount of spark. Dwell time putsa limitation on higher RPM, because at higher RPM thedwell time is not enough to fully charge the inductioncoil. That means less voltage spark at higher RPM.

TCI USING ANGULAR TIMER

The PIC16F161X family of 8-bit PIC microcontrollershas a core independent peripheral called AngularTimer which can be used in internal combustionengines to fire the spark at the exact firing angle withvery little CPU intervention.

Figure 2 illustrates the TCI implementation usingAngular Timer along with additional CIPs that areavailable on the PIC16F1615/9 MCU.

FIGURE 2: TCI USING ANGULAR TIMER

Core Independent Peripherals of PIC microcontrollers,such as Configurable Logic Cell (CLC), Angular Timer(AT), Signal Measurement Timer (SMT) and MathAccelerator are used for measuring and calculating thefiring angle and dwell time control in TCI, as explainedbelow.

Note: Orange colored blocks are hardware peripherals.

Blue colored boxes are software parts.

PIC16F161 MCU

Angular Timer

TCI LOGIC

CLC

Map Selection

RPM Calculation

Firing Angle Calculation

ADC

I/O

ThermistorThrottle

RPM

Signal Conditioning

SMT

Math Accelerator

SMTxCPR

Pick-up signal from pulsar coil

Phase Compare 2

ATxCCy

AT Input

AT Period Pulse

Phase Compare 1

ATxCCy

Firing Angle

+

-

12V Battery

Ignition Coil

Spark Plug

IGBT

IGBT Gate Control

ATxRES

Dwell time to Angle

Calculation

Dwell Angle

DS00002095B-page 2 2016 Microchip Technology Inc.

Page 3: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

Signal conditioning circuit

The pulser coil generates timing signals that containboth positive and negative pulses. These pulses are inthe range of ±3V to ±90V, depending on the magneticfield strength of the magnet mounted on the flywheel. Asignal conditioning circuit is used to invert the negativepulse and limit the pulses to a range of 0V to 5V. It isalso used to filter any spurious noise. The signalconditioning circuit will provide two positive outputs,one corresponding to positive pulses and another fornegative pulses. Output of the signal conditioningcircuit is connected to the microcontroller.

Configurable Logic Cell (CLC)

The outputs of the signal conditioning circuit areconnected to CLC. The outputs of the signalconditioning circuit will be in Logic 1 state, except forthe positive and negative pulses from the pick-up coil.The CLC is configured as an XOR gate, so that theCLC output will give positive pulses for both the inputs,as shown in Figure 3. The CLC output is connected tothe Angular Timer input internally. The Angular Timerprovides a period pulse to SMT.

FIGURE 3: SIGNAL CONDITIONING OUTPUT

Signal Measurement Timer (SMT)

For the RPM calculation, a 24-bit Signal MeasurementTimer (SMT) is used. The AT period pulse isproportional to the engine speed. Hence, it is used asinput to the SMT. The SMT is configured in WindowedMeasurement mode with the window input set to ATperiod pulse. The SMT configured in its WindowedMeasurement mode can capture a valuecorresponding to the period of a signal. Thus, the SMTcaptures the value proportional to the RPM into theSMTxCPR register. Whenever the AT gives a periodpulse, the SMT captures the timer value into theSMTxCPR register, resets its timer count and restartscounting. The timer capture into the SMTxCPR registergenerates captured period interrupt.

ADC

An ADC is used to find the engine temperature and thethrottle position (if analog). The throttle position inputcan be either analog or digital. In case of a digitalthrottle position, the wide open throttle (WOT) will beone state and the partially open throttle (POT) will beanother. A look-up table consisting of speed vs. firingangle is stored in memory. This is called a firing MAP.There will be different firing MAPs for different throttlepositions and different temperature ranges.

Pick-up SignalPulser output

PeriodTDC

Input signals to

MCU After signal

conditioning

p_PIP

n_PIP

+ve Advance

pulse

-ve Referencepulse

+5to15V

-5to15V+5V

+5V

CLC (XOR) output

AT Period Pulse

2016 Microchip Technology Inc. DS00002095B-page 3

Page 4: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

TCI logic

RPM CALCULATION

The RPM of the engine can be calculated from theexternal signal frequency fSIGNAL as follows:

EQUATION 1: RPM CALCULATION

FIRING MAP SELECTION

Every engine is associated with a firing map whichshows the relationship between engine speeds in RPMto firing angle of the spark in degrees. These maps varywith different throttle position and engine temperature.Using the current temperature and throttle position, oneof the firing maps is selected.

FIGURE 4: EXAMPLE OF RPM TOFIRING ANGLE (THETA)MAP

Figure 4 shows an example of a firing map. This firingmap is a plot of piecewise linear curve. The red curveshows the RPM to firing angle relation for throttle ON,and the blue curve shows the RPM to firing anglerelation for throttle OFF position.

FIRING ANGLE CALCULATION

To find the firing angle for an engine between two pointsin the map, linear interpolation is used as follows:

EQUATION 2: FIRING ANGLE CALCULATION

In the above equation, the ratio ((y2-y1)/(x2-x1)) isalways constant and is called slope of a straight line.This can be pre-calculated for a curve to reduce theamount of calculation.

For example, Table 1 is the firing map given by enginespecifications. The values in the “Slope” column arecalculated from the previous two column values, andare called line slope.

fsignalSMTxCLK

SMTPrescalar SMTxCPR------------------------------------------------------------------------=

RPMEngineSMTxCLK

SMTPrescalar SMTxCPR------------------------------------------------------------------------ 60=

Where,

SMTxCLK = clock input for SMT using SMTxCLK register =Fosc = 32 MHz

SMTPRESCALAR = SMT clock prescaler selected inSMTx CON0 = 1:8 = 8

SMTxCPR is the captured value of SMTxTMR at windowinput event

fSIGNAL is the input signal frequency to AT and SMT

60 scalar value is multiplied to convert Hz to RPM,RPMENGINE = fSIGNAL x 60

y y1 x x1– y2 y1–

x2 x1–-----------------+=

Where,

y = the instantaneous value of the firing angle to be calcu-lated, which is in between y1 and y2

x = the instantaneous value of engine RPM, which is knownand in between x1 and x2

(x1, y1) and (x2, y2) = the successive points in the graphbetween which a line is drawn. These are shown as row 1and row 2 in the firing map table, respectively.

x1, x2 = values of Engine RPM of two endpoints

y1, y2 = values of the firing angle of two endpoints of astraight line curve

DS00002095B-page 4 2016 Microchip Technology Inc.

Page 5: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

EXAMPLE 1:

DWELL ANGLE CALCULATION

Dwell time is converted to phase angles correspondingto RPM and can be stored as dwell map similar to thefiring map. Dwell angle value is stored into the AngularTimer Compare 1 register. The firing angle value isstored into the Angular Timer Compare 2 register.

TABLE 1: FIRING MAP FOR EXAMPLE ENGINE

Engine Speed (RPM) Firing Angle (θ°) Slope (m) Dwell Time (mS) Dwell Angle (θ°) Dwell Slope (m)

250 4 0 5 8 0.028

500 4 0.02 5 15 0.04

550 5 0 5 17 0.02889

1000 5 0 5 30 0.032

1250 5 0.016 5 38 0.028

1500 9 0.016 5 45 0.032

1750 13 0.008 5 53 0.028

2000 15 0.004 5 60 0.032

2250 16 0.016 5 68 0.028

2500 20 0 5 75 0.03067

3250 20 0.008 5 98 0.028

3500 22 0 5 105 0.03

7500 22 0 5 225 0

Suppose, RPMENGINE = 2400 rpm. From Table 1, this RPM value lies between 2250 rpm with a firing angle of 16˚ and2500 rpm with a corresponding firing angle of 20˚. Hence, from Equation 2, the resulting terms are: y1 = 16, y2 = 20,x1 = 2250, x2 = 2500, x = 2400.

Hence,

Therefore, the firing angle for the given RPM is 18°.

y 16 2400 2250– 20 16–2500 2250–------------------------------+ 18.4 18= =

2016 Microchip Technology Inc. DS00002095B-page 5

Page 6: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

EXAMPLE 2: DWELL AND FIRING ANGLE CALCULATION

MATH ACCELERATOR

The Math Accelerator peripheral, also called the PIDmodule, is used to calculate the firing angle and thedwell angle for current RPM using linear interpolation,as shown in Equation 2. Using the Math Acceleratorthe calculation can be done faster. It performs anaddition and a multiplication as shown below:

EQUATION 3:

The Math Accelerator performs these operations in16-bit integer, either in signed or unsigned formatconfigured by the user. The result of this operation is32-bit in size, stored into the PIDxOUT register. Theresult of this operation can be configured to beaccumulated or non-accumulated. For accumulation ofthe result, the PIDxACC register is used to accumulateprevious results.

ANGULAR TIMER

The dwell and the firing angle values are calculatedusing the Math Accelerator. Dwell angle value is storedinto the Angular Timer Compare 1 register. The firingangle value is stored into the Angular Timer Compare2 register.

Dwell time can be converted to dwell angle using the following equation:

Suppose, RPMENGINE = 2000 rpm

The angle between advance pulse and TDC = 39° From Table 1, the RPM value has a firing angle of 20° The dwell angle for 5 mS dwell time and 2000 RPM is

So, the IGBT should be turned ON for 60° before the firing event.

If an angle of 0° is considered at advance pulse, then the value to insert in the Compare 1 register for starting the dwelltime is:

And for the firing event the value to insert in the Compare 2 register is:

Ddwell time in ms 0.001 360

period of pick-up signal-------------------------------------------------------------------------------

dwell time in ms 0.001 3601

RPM 60---------------------------

-------------------------------------------------------------------------------= =

D5 0.001 360

12000 60----------------------

----------------------------------------- 60= =

ATCCY1 39 20– 60– 41– 360 41– 319= = = =

ATCCY2 39 20– 19= =

R A B+ C=Where,

A = the first input operand for addition (PIDxIN register)

B = the second input operand for addition (PIDxSETregister)

C = the third input operand for multiplying with result ofaddition (PIDxK1 register)

R = the results of one complete add and multiply operation(PIDxOUT register)

DS00002095B-page 6 2016 Microchip Technology Inc.

Page 7: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE 5: TCI TIMING DIAGRAM

When the value in the Compare 1 register matches theAT phase counter, a compare interrupt is generatedand the IGBT is turned ON, as shown in Figure 5. Thisinitiates the charging of the primary of an ignition coil.The primary of the ignition coil is charged for aparticular dwell time. When the value in the Compare 2register matches the AT phase counter, a compareinterrupt is generated and the IGBT is turned OFF todisconnect the primary of the ignition coil. At this firingevent the magnetic field around the ignition coil’ssecondary windings collapses and the spark isgenerated.

DEBUG MODE

In case of a Debug mode, a connection to the PC GUIcan be provided using UART. The firing MAP or specificparameters like PIP distance or dwell time can bechanged on the fly using a PC-based GUI and an USBto UART converter. For details regarding the enginetuning GUI, refer to Appendix B: “Debug Mode andEngine Tuning PC GUI”.

Pick-up SignalPulser output

PeriodTDC

+ve Advance

pulse

-ve Referencepulse

+5to15V

-5to15V

IGBT trigger from MCU

Firing Angle ΘF

TDC

360°

ATxPHSPhase Counter

CLC (XOR) output

AT Period Pulse

Advance Angle ΘA

DwellTime

IGBT ON

IGBT OFF

2016 Microchip Technology Inc. DS00002095B-page 7

Page 8: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

TCI INTEGRATED WITH RKE, BIKEFINDER AND IMMOBILIZER

Using Core Independent Peripherals (CIPs) for theimplementation of a TCI system frees up the CPU timeand also reduces the code size which can be utilizedfor adding different enhancement features to thesystem, such as Remote Keyless Entry (RKE) (i.e.,anti-theft remote lock, bike finder and immobilizer, etc.).The following section explains the implementation of aTCI system integrated with RKE, bike finder andimmobilizer functionalities.

FIGURE 6: TCI INTEGRATED WITH RKE, BIKE FINDER AND IMMOBILIZER

PIC16F161x MCU

Angular Timer

TCI LOGIC

CLC

MapSelection

RPMCalculation

Firing AngleCalculation

ADC

I/O

ThermistorThrottle

RPM

SignalConditioning

SMT

Math Accelerator

SMTxCPR

Pick up signalfrom pulsar coil

PhaseCompare 2

ATxCCy

ATInput

AT Period Pulse

PhaseCompare 1

ATxCCy+

12V Battery

IgnitionCoil

SparkPlug

IGBT

IGBT GateControl

ATxRES

Dwell timeto Angle

Calculation

DwellAngle

LF Initiator

Timer /CCP

(capture)

125 kHz /13.56MHz

Keyfob

RFReceiverMICRF229

433MHz

PKE+Immobilizer

RKE + BikeFinder

RKE + ImmobilizerLOGIC

Ignition Enable

Firing Angle

CLC

Vehicle Finder

KEELOQ®Decoder

I/O Vehicle FinderLED and Buzzer

PWM

IgnitionEnable

KEELOQ transponderHCS410 (125KHz)Or PIC16F150x +MICRF112 (13.56MHz)

or

HF SupplyTransformer

DS00002095B-page 8 2016 Microchip Technology Inc.

Page 9: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

Remote Keyless Entry (RKE) and BikeFinder System

The Remote Keyless Entry (RKE) system is anelectronic lock that controls the access to a vehiclewithout using a traditional mechanical key. Widely usedin automobiles, an RKE performs the functions of astandard mechanical key without physical contact.When within a few yards of the vehicle, pressing abutton on the remote keyfob can lock or unlock thevehicle, and may perform other functions like vehiclefinder. When the remote lock is switched on, the vehiclecould be started only when the remote lock is openedor unlocked and the ignition keys are turned ON.

The RKE and the bike finder system consists of twoblocks: a keyfob or remote, and an RF receiver on thevehicle side.

Keyfob

There are three different push button keys on a keyfob:lock, unlock and bike finder. For a different key pressusing a push button on the key, the transponder in thekey sends a stream of 64 or 128 bits of encoded datato the key’s RF transmitter. The transmitter modulatesthe carrier and the data is radiated through a simpleprinted circuit loop antenna. The wireless carrierfrequency by the RKE system is currently 315 MHz inthe US/Japan and 433.92 MHz (ISM band) in Europeand Asia.

The same keyfob can be used both for RKE andimmobilizer functionalities.

The 64-bit KEELOQ encrypted data stream is shown inFigure 7.

FIGURE 7: 64-BIT KEELOQ ENCRYPTED DATA

RF RECEIVER IN VEHICLE SIDE

The vehicle side consists of an RF receiver, where thedata sent by the keyfob is captured. Themicrocontroller then decodes the captured data. It thensends an appropriate message to lock or unlock thevehicle. If the vehicle is parked in a crowded parking lot,the bike finder key can be pressed to locate the vehicle.If the bike finder key is pressed, then flash lights on thevehicle can be lit and blinked along with the buzzerbeep, so that the user can easily locate the vehicle.

RF receiver

An RF receiver, MICRF229, is used in this design.

For the details on how to implement the RF receiversection, refer to “MICRF229-433 Evaluation BoardUser Guide”.

The RF receiver to microcontroller interface is shown inFigure 8.

2016 Microchip Technology Inc. DS00002095B-page 9

Page 10: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE 8: RF RECEIVER TO MCU INTERFACE

Immobilizer or Passive Keyless Entry (PKE)

An immobilizer is an electronic security device fitted toan automobile to prevent the engine from running,unless the correct key or other token is present. Thisprevents the vehicle’s theft.

Whenever a keyfob comes in proximity of a vehicle, themicrocircuit inside the key is activated by a smallelectromagnetic field produced by a coil in theimmobilizer unit on the vehicle. This induces current toflow inside the key body, and the keyfob is powered.The keyfob then broadcasts a unique binary code. Thiscode is read by the automobile’s immobilizer unit.When the immobilizer unit determines that the codedkey is both current and valid, it enables the ignition.

The immobilizer or Passive Keyless Entry (PKE) canbe implemented using two different methods:

1. Using 125 kHz Low Frequency (LF)

2. Using 13.56 MHz High Frequency (HF)

IMMOBILIZER WITH 125 kHz (LF)

The immobilizer unit at the vehicle’s side produces amagnetic field of 125 kHz periodically.

Keyfob uses a HCS410 device, which is a low-frequency (LF) transponder (battery less) plus aKEELOQ® encoder in a single chip.

The coil in the immobilizer unit is part of the ResistanceInductor Capacitor (RLC) circuit. The immobilizer unitcommunicates to the transponder by switching the125 kHz signal to the series RLC circuit ON and OFF.Thus, the immobilizer unit’s magnetic field is switchedON and OFF. The transponder coil is connected inparallel with a resonating capacitor (125 kHz) and aKEELOQ HCS410 transponder integrated circuit. Whenthe transponder in the keyfob is brought into theproximity of the immobilizer unit’s magnetic field, itmagnetically couples with it and draws energy from it.Even if the battery in the keyfob goes flat, the HCS410will still be able to get power from the field generated bythe immobilizer unit’s coil. The voltage on the coil canreach over 400 VPP and has a peak current of 1A.

The keyfob then broadcasts a unique binary key code.This code is read by the automobile’s immobilizer unit.When the immobilizer unit validates the key, it enablesthe ignition and the vehicle is mobilized.

IMMOBILIZER WITH 13.56 MHz HIGHFREQUENCY (HF)

The immobilizer unit at the vehicle side produces amagnetic field of 13.56 MHz periodically. Theimmobilizer unit at vehicle side has a 13.560 MHz high-frequency loose transformer circuit, as shown inFigure 9. The transformer can be formed using a PCBantenna, also called a coil. Its function is to supplyenergy to the keyfob, in case there is valid low-powerkeyfob condition detection. The 13.560 MHz oscillatorand amplifier have to condition the signal for properlydriving the HF supply transformer. A low voltagecondition can be sent as one of the commands in thekeyfob transmitter side, when that condition exits,alerting the user to replace the battery. To obtainmaximum performance, a band-pass filter and amatching network are used.

DS00002095B-page 10 2016 Microchip Technology Inc.

Page 11: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE 9: VEHICLE SIDE RECEIVER AND HF TRANSFORMER

The keyfob uses a PIC16F microcontroller along withthe MICRF112 RF 433 MHz transmitter, as shown inFigure 10. The 13.56 MHz high-frequency (HF)transformer uses loose coupling transformertechniques to harvest energy from another similar typeof transformer (immobilizer unit side) to supply energyto the keyfob in a low battery (less than 1.8 volts)

condition. This part of the circuit ensures operation in acondition with low voltage battery. The matchingnetwork and low pass filter circuits are needed to obtainmaximum power efficiency and get rid of undesiredharmonics and spurs. The LDO ensures that no highvoltage from the high-frequency transformer goes tothe rest of the circuit.

FIGURE 10: KEYFOB FOR 13.56 MHz IMMOBILIZER AND RKE

BPFMatching Network

RF ReceiverMICRF229

PIC16F161MCU

DO

SCLK

RSSI INDICATORS/LED

AMPLIFIER EN

BUZZER/HORN

IGNITION EN

13.56 MHz OSCILLATOR

AMPLIFIER

REF

HF SUPPLY TRANSFORMER

433.92 MHz

BPFMatching Network

RF TransmitterMICRF112

PIC16F150XMCU

LOCK

UNLOCK EN

ASK

13.56 MHz

VBAT

REF

HF SUPPLY TRANSFORMER

433.92 MHz

LED

LDO

30 dB Att

VBATVBATVBAT

RF Power Switch

2016 Microchip Technology Inc. DS00002095B-page 11

Page 12: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

The advantages of using a 13.56 MHz frequencyinstead of 125 kHz for energy harvesting are thefollowing:

1. In case of a 125 kHz system, the voltage on thecoil at immobilizer side can reach over 400 VPP

and has a peak current of 1A for generating thestrong magnetic field. Whereas a 13.56 MHzsystem is a low-power one.

2. Air core transformer winding is required in caseof a 125 kHz system. Whereas, for the HF trans-former the PCB antenna will be enough. Thesize of the PCB antenna required for a HF trans-former implementation with 13.56 MHz will besignificantly reduced compared to the 125 kHzsystem.

3. The overall cost of the immobilizer unit, whichuses a 13.56 MHz energy harvesting scheme,will be smaller than with a 125 kHz system.

DS00002095B-page 12 2016 Microchip Technology Inc.

Page 13: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIRMWARE

The firmware flowchart is shown in Figure 11.

FIGURE 11: FIRMWARE FLOWCHART

Program Flow

The program execution is divided into two major parts:

1. The RF receiver section with KEELOQ decoding.

2. The TCI ignition system section.

The Reset state will be Locked state. It will wait for theunlock key press to start the ignition. If a bike finder keyis pressed, then the signals to blink the flash lights onthe vehicle and to beep the buzzer are sent. When theunlock key press is authenticated, the ignition systemwill start functioning.

For KEELOQ decoding algorithms refer to applicationnote AN744, “Modular Mid-range PICmicro® KEELOQ®

Decoder in C” (DS00744).

The ignition part of the firmware is sequentially dividedinto steps to compute the RPM and firing angle asexplained below:

1. Initialize: The board is powered on or reset; allthe peripherals (i.e., ADC, PID, CWG, CLC1,SMT1 and AT1 are initialized). Please refer toAppendix C for initialization of peripherals usingMPLAB® Code Configurator (MCC).

2. Input Acquisition: The CLC1 takes two inputsto generate one XOR-ed output connected tothe AT input. AT starts counting and gives periodpulses. This AT period pulse is used by the SMTas window input in the Windowed Measuremode. The SMT at every AT period inputcaptures the value of the SMT1TMR register toSMT1CPR, and a corresponding interrupt isgenerated. The program is notified about thenew SMT value available for calculation. This isthe acquisition step.

3. ADC: The engine temperature and throttleposition sensor’s analog output is digitized bythe internal 10-bit ADC.

Start

Initialize

AT period Int? & STEP = 0?

AT1CC1 Int? AT1CC2 Int?ADC Int? & STEP = 2?

SMT1 Int? & STEP = 3?

Calculate RPM from SMT timer

Convert ADC to Temperature

Mode = Thermister?

Mode = Throttle?

Mode = Thermister

Mode = Throttle

Convert ADC to Throttle

Set STEP = 2

Select Firing Map using Temperature

and Throttle

STEP = 1?

Get and calculate Dwell angle and Firing

angles using MAP

SetAT1CC1 = Dwell Angle

(IGBT ON)AT1CC2 = Firing Angle

(IGBT OFF)

IGBT Switch ON for

Ignition coil charging

IGBT Switch

OFFSpark

Set STEP = 3

Set STEP = 1

ADC channel = Themister

ADC channel = Temperature

Set STEP = 0

YES

NO NO NO NO NO

YES

YES

NO

NOYES

YESYES YES

Locked state

Unlock?

Spark Generation state

NO

Lock?

NO

Yes

Yes

NOLocate Vehicle?

Flash IndicatorsBeep Buzzers

Yes

No

2016 Microchip Technology Inc. DS00002095B-page 13

Page 14: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

4. RPM calculation: The engine RPM iscalculated from the SMT1CPR register value.

5. MAP selection: Using temperature and throttleposition values, a particular MAP is selected.From this selected MAP, the firing anglecorresponding to the present RPM is read fromthe look-up table. If the current RPM is inbetween the values stored in the look-up table,then the firing angle and the dwell angle for thatRPM is calculated using interpolation.

6. Dwell and firing angle update: The dwell angleand the firing angle values are stored in theAngular Timer Compare 1 registers (AT1CC1)and Compare 2 registers (AT1CC2),respectively.

7. Angular Timer Compare interrupt 1: UponAngular Timer Compare 1 event, Logic 1 isgiven to the port pin connected to the IGBT gate.The IGBT is turned ON to start the charging ofthe ignition coil.

8. Angular Timer Compare interrupt 2: UponAngular Timer Compare 2 event, Logic 0 isgiven to the port pin connected to the IGBT gate.The IGBT is turned OFF, so that the charging ofthe ignition coil is interrupted and the spark isgenerated.

9. Steps 2 to 8 are repeated at every AT periodcycle.

COMPARISON BETWEEN TCI USINGANGULAR TIMER AND TCI USINGTHE TRADITIONAL APPROACH

Firing Angle to Timer Counts Conversion

For the traditional method, the firing angle has to beconverted to corresponding timer counts.

Whereas, the firing angle value obtained from the MAPcan be directly written to the Angular Timer Compareregister. When the angle value matches, it generatesan interrupt and the IGBT can be turned OFF. There isno CPU intervention, because the Angular Timer is aseparate on-chip peripheral.

For the TCI system, if using the Angular Timer, it isneeded to convert the dwell time to correspondingangle for every RPM.

Interpolation Calculation for Firing Angle

For the traditional method, the interpolation calculationof the firing angle and the conversion of the firing angleto timer count calculation take longer.

By using the Math Accelerator, the firing and the dwellangle interpolation calculations can be expedited.

RPM calculation

When applying the traditional method, for lower RPMsthere is the possibility of timer overflow.

SMT is a 24-bit timer. If used for RPM calculations withclock frequency of 1 MHz, it can count till 0.125 Hz (i.e.,7.5 RPM without overflow).

Resolution

With the traditional method, the angular resolutionvaries depending on the RPM.

Whereas, the desired resolution of the firing angle canbe directly loaded into the resolution register (ATxRES)of the Angular Timer. For a resolution of 1° theresolution register is loaded with a value of 359 in caseof Single Pulse mode. The angular resolution isindependent of the engine RPM.

Overall Comparison

The maximum frequency of the input pick-up signal tothe TCI system can be 190 Hz corresponding to11,400 RPM (i.e., 190 Hz (period 5.263 ms)). Withinthis period of 5 ms, the TCI operation must finish all theexecution and calculations. Considering the PIC16Fdevices for both traditional method and using theAngular Timer, which has 8 MIPS of execution speed at32 MHz, the comparison table below shows the CPUusage for both systems.

The MIPS can be calculated as in Equation 4:

EQUATION 4:

In this case, the TMIN = 5 ms and the MIPSTOTAL = 8.

Thus, CPU usage based on max MIPS is given inEquation 5:

EQUATION 5:

MIPSActual

MIPSTotalTMIN

----------------------------- TExecution=

Where,

MIPSACTUAL = the calculated MIPS for current programexecution

TMIN = the minimum input period which is 1/fMAX, i.e.inverse of minimum input signal frequency

MIPSTOTAL = the max MIPS of the device

TEXECUTION = the actual execution time of program

%CPUUsage

MIPSActualMIPSTotal

-------------------------------- 100=

DS00002095B-page 14 2016 Microchip Technology Inc.

Page 15: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

Table 3 summarizes the resource comparisons of twomethods for TCI implementation and TCI withintegrated RKE, bike finder and immobilizer:

Table 4 summarizes the performance comparisons oftwo methods for CDI implementation:

TABLE 2: TIMING COMPARISON

Program Operations

TCI using Angular Timer TCI using Traditional Method

Execution Time (µs) MIPS% CPU Usage

Execution Time (µs) MIPS% CPU Usage

Long Division 150 0.24 3 200 (extra time for T1 count overflow value inclusion in calculation)

0.32 4

Firing Angle Calculation

150 (Using Math Accelerator)

0.24 3 350 0.56 7

Dwell Angle Calculation

150 (Using Math Accelerator)

0.24 3 0 0 0

T1 count to degree

0 0 0 200 0.32 4

ISR and other program commands

50 0.08 1 50 0.08 1

Total 500 0.8 10 800 1.28 16

TABLE 3: RESOURCE COMPARISON

Parameters TCI using Angular TimerTCI using traditional

methodTCI with Integrated RKE, Bike

Finder and Immobilizer

Flash Memory (Words) 2226 3502 3265

RAM (Bytes) 80 270 345

Peripherals Used ADC, CLC, AT, SMT, Math Accelerator

ADC, CCP, Timer1 ADC, CLC, AT, SMT, Math Accelerator, Timer

TABLE 4: PERFORMANCE COMPARISON

Parameters TCI using Angular Timer TCI Using Traditional Method

Accuracy Depends on FOM and ATxRES value Depends on engine speed (i.e., RPM and granularity of timer count for firing angle calculation).

Resolution Minimum 0.35° resolution (i.e., 10-bit ATxRES value)

Depends on Timer1 clock and RPM. E.g., for 1 MHz clock and 250 RPM the angular resolution is 0.09°, and for 10,000 RPM the angular resolution is 3.6°.

2016 Microchip Technology Inc. DS00002095B-page 15

Page 16: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

CONCLUSION

The TCI system can be implemented using PIC16Fmicrocontrollers either by applying the traditionalmethod or by using CIPs like AT, CLC, SMT, MathAccelerator and CWG. However, using the CIPs greatlyimproves the overall performance and implementationof the TCI. The AT successfully divides the input signalto angular division without CPU intervention, whichhelps to boost the performance and hence, removingthe need for firing angle conversion from degree toequivalent time. These angular divisions are alsoaccurate and constant throughout the input signalrange. As shown in the comparison Table 2, Table 3and Table 4, the performance of the TCI system can begreatly enhanced using CIPs like Angular Timer, MathAccelerator and SMT, etc. In addition, with the use ofthe Math Accelerator, the calculations are now moreaccurate and faster. The SMT with its inherent high-bitresolution helps in tracking low engine RPMs andtaking necessary action, without the need for largecomputations. Hence, the remaining CPU bandwidthcan be used for adding other enhancement featureslike anti-theft remote lock (RKE), bike finder andimmobilizer.

DS00002095B-page 16 2016 Microchip Technology Inc.

Page 17: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

APPENDIX A: SCHEMATICS/PCB FILES AND REFERENCE DESIGN

For schematics/PCB files and reference board, contactthe local Microchip sales office.

FIGURE A-1: TCI BOARD

2016 Microchip Technology Inc. DS00002095B-page 17

Page 18: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

APPENDIX B: DEBUG MODE ANDENGINE TUNING PCGUI

This appendix explains the PC-based GUI application,which is developed for debugging and engine tuning ofa TCI/CDI system.

As explained in the previous sections, microcontroller-based TCI/CDI applications have a timing/firing map/look-up table to handle the advance of the ignitiondepending upon the engine speed, temperature andthrottle position. These are based on the ignition timingadvance characteristics specified by the enginemanufacturers. Tuning a TCI/CDI system by varyingfiring angles at different RPMs aids in checking andimproving the efficiency, thereby enhancing theperformance of the engine.

Installation and Usage of the DesktopApplication

1. Start the IgnitionSystemTuning.exeapplication. Figure B-1 shows the GUI of thetuning application.

DS00002095B-page 18 2016 Microchip Technology Inc.

Page 19: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

2

01

6 M

icroch

ip T

ech

no

log

y Inc.

DS

00

00

20

95

B-p

ag

e 1

9

AN

2095

FIG

Asboanva

URE B-1: DEBUGGING/TUNING APPLICATION AT START-UP

shown in Figure B-1, in the top left corner of the GUI is the Engine Settingsx. The Settings dialog box requires the user to enter the engine parametersd the Angular Timer parameters for MAP generation and tuning. Theselues can be changed by the user at any time.

Page 20: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE B-2: ENGINE SETTINGS

2. On the left side, the GUI has a table consistingof three columns:

• Engine speed in RPM• Firing Angle in Degrees• Dwell Time in µs

In the middle, there are two text boxes labeled“Application Messages” and “Application DebugInformation”. “Application Messages” displays errorsand any message during operation. “Application DebugInformation” displays the real-time engine parameterslike engine speed, firing angle, dwell angle,temperature and throttle position etc.

3. The application has a menu labeled“Application” on the topmost left corner. Uponclicking on it, it displays various options, such as“Clear All” and “File. “Clear All” menu optionclears all the text boxes and the user details ofthe engine in Settings and the table. It resets theGUI to its default state. The “File” menu has twooptions: Save and Load. The Save option savesthe engine information entered by the user in afile at a user-specified location. The Load optionloads the engine information file from a user-defined location.

4. The Application has a menu labeled “Debug”. Tostart the debug messages click on the Debugmenu and select “ON”. The application sends arequest to the TCI/CDI board to send the real-time ignition data to the user for display. To stopthe debug messages getting displayed on theGUI, click on the Debug menu and select“OFF”. The application requests the TCI/CDIboard to stop the transmission of real-timedebug messages to the GUI.

5. The functions of various buttons on the GUI arelisted below:

LOAD MAP – When this button is clicked, theapplication finds any connected TCI/CDI boardand starts sending the tuning MAP data and theengine parameters set by the user. If the datatransmission is successful, a success messageis displayed. If the data transmission is notsuccessful, an error message will appear. If anerror occurs, it tries to resend the data two moretimes.

START – When this button is clicked, the tuningoperation with the TCI/CDI board will begin. Theboard sends real-time data and it is displayed onthe GUI.

STOP – When this button is clicked, the tuningoperation with the TCI/CDI board is stopped andthe board is reset for normal operation.

6. The right side of the GUI shows the animatedreal-time data. During the tuning process, datasuch as IGBT angle turn ON, IGBT angle turnOFF, temperature and throttle position, isdisplayed visually, as well as in text format, asshown in Figure B-3.

DS00002095B-page 20 2016 Microchip Technology Inc.

Page 21: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

2

01

6 M

icroch

ip T

ech

no

log

y Inc.

DS

00

00

20

95

B-p

ag

e 2

1

AN

2095

Fig

FIG

ure B-3 shows the GUI screen during the tuning process.

URE B-3: TUNING WITH GUI

Page 22: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

APPENDIX C: MPLAB® CODE CONFIGURATOR (MCC)

The MPLAB® Code Configurator (MCC) plug-in for MPLAB X can be used to configure the peripherals in

the PIC® MCU. The MCC provides graphical user interface (GUI) tools to easily understand the configuration and select the required settings. This reduces the time to development. The MCC also provides some built-in functions for working with specific peripherals.

To install MCC, go to Tools Plugins Available

Plugins MPLAB X Code Configurator Install. To

start and use the MCC after installation, go to Tools

Embedded MPLAB Code Configurator.

Figure C-1 to Figure C-6 shows the configuration of thePIC16F1619 device peripherals such as AT, CLC,Math Accelerator, SMT and EUSART, respectively,used in the TCI implementation.

FIGURE C-1: AT CONFIGURATION IN MCC FOR PIC16F1619

DS00002095B-page 22 2016 Microchip Technology Inc.

Page 23: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE C-2: CLC CONFIGURATION IN MCC FOR PIC16F1619

FIGURE C-3: MATH ACCELERATOR CONFIGURATION IN MCC FOR PIC16F1619

2016 Microchip Technology Inc. DS00002095B-page 23

Page 24: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE C-4: SMT1 CONFIGURATION IN MCC FOR PIC16F1619

FIGURE C-5: EUSART CONFIGURATION IN MCC FOR PIC16F1619

DS00002095B-page 24 2016 Microchip Technology Inc.

Page 25: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

FIGURE C-6: MCC GENERATED FILES AND FOLDER STRUCTURE

After all the settings are selected in MCC, click theGenerate Code button to generate the peripheralcode, and create a header and a C file for every periph-eral separately. Figure C-6 shows the files created andarranged under the MCC Generated Files folder for TCIimplementation using AT. The programmer should addthe application code wherever it is required in thesefiles.

2016 Microchip Technology Inc. DS00002095B-page 25

Page 26: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

AN2095

APPENDIX D: REFERENCES

1. PIC16(L)F1615/9 14/20-Pin, 8-Bit FlashMicrocontroller Data Sheet (DS40001770)

2. RF Receiver MICRF229 Data Sheet

3. MICRF229-433 Evaluation Board User’s Guide

4. AN744, Modular Mid-Range PICmicro®

KEELOQ® Decoder in C (DS00744)

5. TB003, An Introduction to KEELOQ® CodeHopping (DS91002)

6. TB001, Secure Learning RKE Systems UsingKEELOQ® Encoders (DS91000)

7. HCS410 KEELOQ® Code Hopping Encoder andTransponder Data Sheet (DS40158)

8. AN650, Designing a Transponder Coil for theHCS410 (DS00650)

DS00002095B-page 26 2016 Microchip Technology Inc.

Page 27: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

Note the following details of the code protection feature on Microchip devices:

• Microchip products meet the specification contained in their particular Microchip Data Sheet.

• Microchip believes that its family of products is one of the most secure families 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 Microchip products in a manner outside the operating specifications contained in Microchip’s Data Sheets. Most likely, the person doing so is 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 ourproducts. Attempts to break Microchip’s code protection feature may be a violation of the Digital Millennium Copyright Act. If such actsallow unauthorized access to your software or other copyrighted work, you may have a right to sue for relief under that Act.

Information contained in this publication regarding deviceapplications and the like is provided only for your convenienceand may be superseded by updates. It is your responsibility toensure that your application meets with your specifications.MICROCHIP MAKES NO REPRESENTATIONS ORWARRANTIES OF ANY KIND WHETHER EXPRESS ORIMPLIED, WRITTEN OR ORAL, STATUTORY OROTHERWISE, RELATED TO THE INFORMATION,INCLUDING BUT NOT LIMITED TO ITS CONDITION,QUALITY, PERFORMANCE, MERCHANTABILITY ORFITNESS FOR PURPOSE. Microchip disclaims all liabilityarising from this information and its use. Use of Microchipdevices in life support and/or safety applications is entirely atthe buyer’s risk, and the buyer agrees to defend, indemnify andhold harmless Microchip from any and all damages, claims,suits, or expenses resulting from such use. No licenses areconveyed, implicitly or otherwise, under any Microchipintellectual property rights unless otherwise stated.

2016 Microchip Technology Inc.

Microchip received ISO/TS-16949:2009 certification for its worldwide headquarters, design and wafer fabrication facilities in Chandler and Tempe, Arizona; Gresham, Oregon and design centers in California and India. The Company’s quality system processes and procedures are for its PIC® MCUs and dsPIC® DSCs, KEELOQ® code hopping devices, Serial EEPROMs, microperipherals, nonvolatile memory and analog products. In addition, Microchip’s quality system for the design and manufacture of development systems is ISO 9001:2000 certified.

QUALITY MANAGEMENT SYSTEM CERTIFIED BY DNV

== ISO/TS 16949 ==

Trademarks

The Microchip name and logo, the Microchip logo, AnyRate, dsPIC, FlashFlex, flexPWR, Heldo, JukeBlox, KEELOQ, KEELOQ logo, Kleer, LANCheck, LINK MD, MediaLB, MOST, MOST logo, MPLAB, OptoLyzer, PIC, PICSTART, PIC32 logo, RightTouch, SpyNIC, SST, SST Logo, SuperFlash and UNI/O are registered trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

ClockWorks, The Embedded Control Solutions Company, ETHERSYNCH, Hyper Speed Control, HyperLight Load, IntelliMOS, mTouch, Precision Edge, and QUIET-WIRE are registered trademarks of Microchip Technology Incorporated in the U.S.A.

Analog-for-the-Digital Age, Any Capacitor, AnyIn, AnyOut, BodyCom, chipKIT, chipKIT logo, CodeGuard, dsPICDEM, dsPICDEM.net, Dynamic Average Matching, DAM, ECAN, EtherGREEN, In-Circuit Serial Programming, ICSP, Inter-Chip Connectivity, JitterBlocker, KleerNet, KleerNet logo, MiWi, motorBench, MPASM, MPF, MPLAB Certified logo, MPLIB, MPLINK, MultiTRAK, NetDetach, Omniscient Code Generation, PICDEM, PICDEM.net, PICkit, PICtail, PureSilicon, RightTouch logo, REAL ICE, Ripple Blocker, Serial Quad I/O, SQI, SuperSwitcher, SuperSwitcher II, Total Endurance, TSHARC, USBCheck, VariSense, ViewSpan, WiperLock, Wireless DNA, and ZENA are trademarks of Microchip Technology Incorporated in the U.S.A. and other countries.

SQTP is a service mark of Microchip Technology Incorporated in the U.S.A.

Silicon Storage Technology is a registered trademark of Microchip Technology Inc. in other countries.

GestIC is a registered trademarks of Microchip Technology Germany II GmbH & Co. KG, a subsidiary of Microchip Technology Inc., in other countries.

All other trademarks mentioned herein are property of their respective companies.

© 2016, Microchip Technology Incorporated, Printed in the U.S.A., All Rights Reserved.

ISBN: 978-1-5224-0426-2

DS00002095B-page 27

Page 28: AN2095 - Transistor Coil Ignition with Integrated Remote ......FIRING ANGLE CALCULATION To find the firing angle for an engine between two points in the map, linear interpolation is

DS00002095B-page 28 2016 Microchip Technology Inc.

AMERICASCorporate Office2355 West Chandler Blvd.Chandler, AZ 85224-6199Tel: 480-792-7200 Fax: 480-792-7277Technical Support: http://www.microchip.com/supportWeb Address: www.microchip.com

AtlantaDuluth, GA Tel: 678-957-9614 Fax: 678-957-1455

Austin, TXTel: 512-257-3370

BostonWestborough, MA Tel: 774-760-0087 Fax: 774-760-0088

ChicagoItasca, IL Tel: 630-285-0071 Fax: 630-285-0075

ClevelandIndependence, OH Tel: 216-447-0464 Fax: 216-447-0643

DallasAddison, TX Tel: 972-818-7423 Fax: 972-818-2924

DetroitNovi, MI Tel: 248-848-4000

Houston, TX Tel: 281-894-5983

IndianapolisNoblesville, IN Tel: 317-773-8323Fax: 317-773-5453

Los AngelesMission Viejo, CA Tel: 949-462-9523 Fax: 949-462-9608

New York, NY Tel: 631-435-6000

San Jose, CA Tel: 408-735-9110

Canada - TorontoTel: 905-673-0699 Fax: 905-673-6509

ASIA/PACIFICAsia Pacific OfficeSuites 3707-14, 37th FloorTower 6, The GatewayHarbour City, Kowloon

Hong KongTel: 852-2943-5100Fax: 852-2401-3431

Australia - SydneyTel: 61-2-9868-6733Fax: 61-2-9868-6755

China - BeijingTel: 86-10-8569-7000 Fax: 86-10-8528-2104

China - ChengduTel: 86-28-8665-5511Fax: 86-28-8665-7889

China - ChongqingTel: 86-23-8980-9588Fax: 86-23-8980-9500

China - DongguanTel: 86-769-8702-9880

China - HangzhouTel: 86-571-8792-8115 Fax: 86-571-8792-8116

China - Hong Kong SARTel: 852-2943-5100 Fax: 852-2401-3431

China - NanjingTel: 86-25-8473-2460Fax: 86-25-8473-2470

China - QingdaoTel: 86-532-8502-7355Fax: 86-532-8502-7205

China - ShanghaiTel: 86-21-5407-5533 Fax: 86-21-5407-5066

China - ShenyangTel: 86-24-2334-2829Fax: 86-24-2334-2393

China - ShenzhenTel: 86-755-8864-2200 Fax: 86-755-8203-1760

China - WuhanTel: 86-27-5980-5300Fax: 86-27-5980-5118

China - XianTel: 86-29-8833-7252Fax: 86-29-8833-7256

ASIA/PACIFICChina - XiamenTel: 86-592-2388138 Fax: 86-592-2388130

China - ZhuhaiTel: 86-756-3210040 Fax: 86-756-3210049

India - BangaloreTel: 91-80-3090-4444 Fax: 91-80-3090-4123

India - New DelhiTel: 91-11-4160-8631Fax: 91-11-4160-8632

India - PuneTel: 91-20-3019-1500

Japan - OsakaTel: 81-6-6152-7160 Fax: 81-6-6152-9310

Japan - TokyoTel: 81-3-6880- 3770 Fax: 81-3-6880-3771

Korea - DaeguTel: 82-53-744-4301Fax: 82-53-744-4302

Korea - SeoulTel: 82-2-554-7200Fax: 82-2-558-5932 or 82-2-558-5934

Malaysia - Kuala LumpurTel: 60-3-6201-9857Fax: 60-3-6201-9859

Malaysia - PenangTel: 60-4-227-8870Fax: 60-4-227-4068

Philippines - ManilaTel: 63-2-634-9065Fax: 63-2-634-9069

SingaporeTel: 65-6334-8870Fax: 65-6334-8850

Taiwan - Hsin ChuTel: 886-3-5778-366Fax: 886-3-5770-955

Taiwan - KaohsiungTel: 886-7-213-7828

Taiwan - TaipeiTel: 886-2-2508-8600 Fax: 886-2-2508-0102

Thailand - BangkokTel: 66-2-694-1351Fax: 66-2-694-1350

EUROPEAustria - WelsTel: 43-7242-2244-39Fax: 43-7242-2244-393

Denmark - CopenhagenTel: 45-4450-2828 Fax: 45-4485-2829

France - ParisTel: 33-1-69-53-63-20 Fax: 33-1-69-30-90-79

Germany - DusseldorfTel: 49-2129-3766400

Germany - KarlsruheTel: 49-721-625370

Germany - MunichTel: 49-89-627-144-0 Fax: 49-89-627-144-44

Italy - Milan Tel: 39-0331-742611 Fax: 39-0331-466781

Italy - VeniceTel: 39-049-7625286

Netherlands - DrunenTel: 31-416-690399 Fax: 31-416-690340

Poland - WarsawTel: 48-22-3325737

Spain - MadridTel: 34-91-708-08-90Fax: 34-91-708-08-91

Sweden - StockholmTel: 46-8-5090-4654

UK - WokinghamTel: 44-118-921-5800Fax: 44-118-921-5820

Worldwide Sales and Service

07/14/15