This invention relates to a wireless transmitter, and more particularly, to a wireless transmitter used with a Keyless Entry System.
A Keyless Entry System (“RKE”) allows a user to lock and unlock doors, sound a panic alarm, program seat and mirror positions, open a trunk, and/or perform other functions using a transmitter.
In Keyless Entry Systems, one or more unique identifying codes are programmed into the transmitter. In these Keyless Entry Systems, the transmitter and a receiver use a defined communication protocol. The communication protocol defines the timing of the bit stream and the tolerances. The transmitter can include a microprocessor that transmits according to a communication protocol. In some Keyless Entry Systems an external oscillator is required to provide a stable and accurate clock reference to the microprocessor. These oscillator circuits can comprise multiple parts that include an external crystal or an external resonator.
In some instances, multiple parts that include an external crystal or an external resonator, for example, can decrease the durability and increase the complexity, the size, the cost of manufacturing, and the cost of assembly of some Keyless Entry Systems. The increased cost of these Keyless Entry Systems can be especially high when large numbers of Keyless Entry Systems are manufactured and/or assembled.
In the figures, like reference numbers designate similar parts through different views.
A presently preferred embodiment of the invention comprises a micro-controller or microprocessor, a timing circuit, and a memory. Preferably, the memory and timing circuit are a unitary part of the micro-controller or microprocessor. Preferably, the memory is programmed to stabilize an output frequency of the timing circuit in response to temperature and voltage variations. A presently preferred method calibrates the output frequency of the timing circuit through a range of operating voltages.
In the presently preferred embodiment, an algorithm adjusts the output frequency of the timing circuit relative to an operating voltage of the micro-controller or microprocessor. Subsequently, the algorithm adjusts the output frequency of the timing circuit relative to an ambient temperature. A second presently preferred method preferably programs the memory with a factor that avoids frequency discontinuities that can occur in the output of the timing circuit. This presently preferred method can be combined with the first presently preferred method to compensate for the frequency drift caused by temperature and voltage variations and avoid the frequency discontinuities that can occur in the output of the timing circuit.
Other apparatuses, systems, methods, features, and advantages of the presently preferred embodiments will become apparent to one with skill in the art upon examination of the figures and detailed description. It is intended that all such additional apparatuses, systems, methods, features and advantages be included within this description, be within the scope of the invention, and be protected by the accompanying claims.
The presently preferred Remote Keyless Entry System (“RKE”) provides users with a convenient apparatus and method for controlling vehicle or other remote structures and systems. The presently preferred Remote Keyless Entry System allows a presently preferred transmitter to be concealed in a housing, a key, a card, a fob, or another device. When activated, the presently preferred transmitter communicates with a receiver or transceiver. Preferably, the communication between the presently preferred transmitter and receiver authorizes access to a vehicle or another remote structure or system. The presently preferred apparatus and method is preferably mechanically activated. However, a preferred alternative apparatus and method can be a unitary part of a hands free system that automatically authorizes access or actuates a function when the transmitter is in proximity to the receiver. Alternatively, the presently preferred apparatus and method can be voice activated.
In one presently preferred embodiment, the presently preferred timing circuit 106 comprises an array of capacitors that are individually selected by transistors under the control of an oscillator calibration (“OSCCAL”) register resident to the microprocessor 104. In this presently preferred embodiment the oscillator calibration register is six bits long, although other register lengths can also be used. Preferably, the six bits represent binary count values that range from zero to sixty-three (“000000” to “111111”). Thus, the greatest number of bit changes occurs through the transition from fifteen to sixteen (“001111” to “010000”), from thirty-one to thirty-two (“011111” to “100000”), and from forty-seven to forty-eight (“101111” to “110000”).
As shown in
I. K-Factor
As shown in
Preferably, a bit time period of the data transmitted from the presently preferred transmitter 100 is comprised of multiple periods of time needed to execute a fixed instruction and one or more adjustable instructions. Preferably, a fixed instruction is an instruction that performs a necessary function. In this presently preferred embodiment, a debounce instruction is a fixed instruction. Preferably, an adjustable instruction is a delaying instruction that is executed to maintain a substantially constant bit time period. In this presently preferred embodiment, the number of adjustable instructions that must be executed to maintain a substantially constant bit time period is called a K-factor. In this presently preferred embodiment, the K factor is an integer constant. In alternative preferred embodiments, the K-factor can comprise one or more real numbers programmed to avoid one or multiple frequency discontinuities that occur through a frequency range.
More precisely, in this presently preferred embodiment the K-factor generates a substantially constant time T2 added to a debounce time T1. Preferably the substantially constant time T2 is a period of time that avoids a frequency discontinuity and further synchronizes communication with a receiver that is integrated within a vehicle, house, enclosure, or other device or structure. For a given operating frequency, the substantially constant time T2 changes when the presently preferred transmitter 100 is calibrated.
Preferably, T1 represents a time needed to detect a switch activation. In this presently preferred embodiment, when the presently preferred transmitter 100 is activated by a switch the opening and closing of that switch may not generate a uniform signal as the switch output transitions between logic states. Instead, the transition can comprise a transient that results from the switch contacts “bouncing” during the switch transition. To ensure that the transient does not cause the microprocessor 104 to detect phantom switching events, preferably a debounce period T1 is added to the constant time period T2 in this presently preferred embodiment. Preferably, during this debounce period an input port is sampled and occurring commands are queued. This guarantees that no switch event is missed during transmission.
II. Calibration
Although communication between the presently preferred transmitter 100 and receiver is preferably an asynchronous process, the “clock” of the presently preferred timing circuit is preferably adjusted to avoid frequency discontinuities and compensated for voltage and temperature variations. As shown in
As shown, the boxes outlined in continuous lines represent functions that are performed by the presently preferred transmitter 100. The dashed boxes represent the functions that are performed by the presently preferred test fixture 102.
Referring to
At act 404, the presently preferred transmitter 100 reads the calibration register. When an expected value is read, such as a “DOH,” the presently preferred calibration process begins, otherwise the presently preferred transmitter 100 operates in a normal mode. At act 404 the calibration process generates a look up table in the EEPROM 108. Preferably, the look up table retains the K-factor, and voltage and temperature compensation values that are used as references in a presently preferred timing circuit adjustment algorithm.
At act 406, a memory pointer (e.g., EE_PTR), a K_flag, a number of voltages (e.g., NumVoltages), the K-factor (e.g., K) are initialized. The oscillator calibration register is initialized with a value so that discontinuities of the oscillator are avoided. Preferably, the memory pointer points to a first data entry within the look up table and the K-flag identifies whether the K-factor has been programmed. Preferably the K-factor ensures that the bit time period is substantially constant.
The presently preferred calibration process continues by adjusting and validating the K-factor before adjusting and validating the contents of the oscillator calibration register. Preferably, the presently preferred test fixture 102 programs the K-factor and the contents of the oscillator calibration register using Up/Down commands that tune the K-factor and the contents of the oscillator calibration register across a range of voltages that comprise the operating voltage range of the presently preferred transmitter 100. By controlling two inputs of the presently preferred transmitter 100, RC0 and RC1, the presently preferred transmitter 100 generates an output pulse proportional to a software-timing loop. While the presently preferred transmitter 100 can transmit a signal within a broad frequency range, for the purpose of explanation the fixed timing loop is preferably tuned to about one millisecond at about a four megahertz “clock” frequency.
Referring again to
When the presently preferred test fixture 102 determines the reference pulse width is longer than the reference period, the presently preferred test fixture 102 drives RC0 to a logic high state and RC1 to a logic low state at act 412. When the presently preferred test fixture 102 determines that the reference pulse width is less than the reference period, the presently preferred test fixture 102 drives RC0 to logic low state and RC1 to a logic high state at act 412. When the presently preferred test fixture 102 determines the reference pulse width is substantially equal to the reference period, the presently preferred test fixture 102 drives RC0 and RC1 to a logic low state at act 412.
When RC0 is at a logic high state and RC1 is at logic low state, the presently preferred transmitter 100 evaluates the K-flag at acts 414 and 502 as seen in
When the presently preferred test fixture 102 determines that the reference pulse width is shorter than the reference period, the presently preferred test fixture 102 drives RC0 to logic low state and RC1 to a logic high state at act 412. At these states, the presently preferred transmitter 102 evaluates the K-flag at acts 424 and 506. If the K-factor has not been programmed, the K_flag will be at a logic low state and the K-factor is decremented at act 508. The presently preferred test fixture 102 then drives RC0 and RC1 to a logic high state at act 420. When the K-factor is programmed, the K_flag will be at a logic high state and the presently preferred transmitter 100 decrements the contents of the oscillator calibration register at act 510. The presently preferred test fixture 102 then drives RC0 and RC1 to a logic high state at act 420.
When the presently preferred test fixture 102 determines the reference pulse width generated by the presently preferred transmitter 100 is substantially equal to the reference period, the presently preferred test fixture drives RC0 and RC1 to a logic low state at act 412. In response, the presently preferred transmitter 102 evaluates the K-flag at act 512. If the K-factor has not been programmed, the K-factor is written into the look up table within the memory 108, such as the EEPROM, and the K-flag is programmed to a logic high state at act 514. If the K-factor has been programmed before act 514, at act 516 the contents of the oscillator calibration register and a memory write time are stored within the look up table stored within the memory 108. Preferably, the memory write time is used to determine an ambient temperature of the presently preferred transmitter 100. At act 518, the memory pointer EE_PTR is incremented and the voltage count is decremented. The above presently preferred process is then repeated until the entire operating voltage range has been calibrated by tracking a voltage index as shown in act 520. In this presently preferred embodiment, the calibration process steps through about two to three and one-tenth volts in increments of about 100 milli-volts as the presently preferred test fixture adjusts supply voltage at act 418. In other alternative preferred embodiments, other voltage ranges and increments can be used.
Once the K-factor and contents of the oscillator calibration register have been established, and retained within the memory 108, preferably an EEPROM, a DigitalOnly flag is programmed to a logic high state, the presently preferred calibration register is programmed with a second reference, here “A5H,” and RC0 and RC1 are driven to logic high states at acts 602-606 of FIG. 6. In response, the presently preferred transmitter 100 generates a two milli-second digital pulse at act 608 that is analyzed and validated at act 610 by the presently preferred test fixture 102. In this presently preferred embodiment, the two milli-second digital pulse is generated at act 608 and the calibration register is reprogrammed with a value other than the expected “DOH” value, here “AH5” at act 606. If the two milli-second digital pulse is validated at act 610, the DigitalOnly flag is programmed to a logic low state at act 422 of
In this presently preferred embodiment, after the EEPROM 108 has been programmed, the presently preferred test fixture 102 issues a pulse on RC0 and RC1 within about thirty two milliseconds to simulate a switching event. This switch event triggers the presently preferred transmitter 100 to transmit a radio frequency modulation signal. At act 610, a radio frequency modulating signal is validated without a radio frequency circuit 110 transmitting a radio frequency signal. The data appears only on a digital output line. If validated, the presently preferred transmitter 102 goes into a normal operation mode. If verification fails as shown in
When the presently preferred test fixture 102 receives the rising edge of the reference signal, the presently preferred test fixture 102 assures that RC0 and RC1 are driven high at act 706. The presently preferred test fixture 102 further prepares a receiver within the presently preferred test fixture 102 to detect the negative or falling edge of the reference signal. When the presently preferred test fixture 102 detects the falling edge of the reference signal, the presently preferred embodiment calculates the pulse width or duration of the reference signal at act 708. If the pulse width of the reference signal is greater than about the desired time interval at act 710, the presently preferred test fixture 102 drives an input to the presently preferred transmitter RC1 to a logic low state at act 712. If the pulse width of the reference signal is less than about the desired time interval at act 714, the presently preferred test fixture 102 drives an input to the presently preferred transmitter RC0 to a logic low state at act 716.
As seen in
As further seen in
If the bit times are verified at act 814, the presently preferred test fixture 102, verifies the K-factor and contents of the oscillator calibration register across the operating voltage range of the presently preferred transmitter 100 at acts 820 and 822. Preferably, the presently preferred test fixture 102 also programs a unique identifying code into each presently preferred transmitter at act 820. If the values stored in the look up table fail verification at act 822, the presently preferred test fixture 100 re-initializes the contents of the oscillator calibration register and the preferred calibration process is repeated at act 824 and at the start link shown in FIG. 7.
III. Current Draw
Once the K-factor and contents of the oscillator calibration register are verified, the presently preferred test fixture 102 monitors current drawn by the presently preferred transmitter 100 when the presently preferred transmitter 100 is in a sleep mode as shown in FIG. 9. Preferably, the presently preferred test fixture 102 monitors the sleep current or average sleep current during a sleep interval. At act 902, the programmable power supply 116 is initialized and the sleep current drawn by the presently preferred transmitter 100 is measured. If the sleep mode consumes less than a referenced current at act 904, in this presently preferred embodiment that being less than about one microampere, the presently preferred test fixture 102 logs a database entry at act 906 and the presently preferred transmitter 100 is passed at act 908. However, if the sleep mode consumes more than about one microampere, the presently preferred test fixture 102 logs a database entry at act 910 and the presently preferred transmitter 100 is failed at act 912.
In view of the foregoing description, it should be noted that the above test can also measure the presently preferred transmitter's 100 operating current consumed during a wakeup interval and the operating and sleep current consumed during a transition between a wakeup and a sleep interval. Moreover, these currents may also be measured across a desired temperature range and evaluated against many other voltage reference ranges.
IV. Switch Debounce During RF Transmission
V. Stretch Time
Preferably, the presently preferred Manchester encoding can be encoded within a time period that includes the stretch time or radio frequency compensation. Preferably, the stretch time compensates for the pulse width reduction due to the time needed to power up a radio frequency transmission circuit. This reduced pulse width results in bit time errors in an AM-RF receiver. Some AM-RF receiver detects the envelope of the received signal. The stretch time compensation substantially eliminates or entirely eliminates this error. Referring to
As shown in the truth table below (Table 1), by evaluating three consecutive bits, the bit timing period can be substantially constant by modifying the period of the high and low time of a binary digit. Preferably, the stretch time compensates for the rise time of a bit as the radio frequency circuit 110 powers up before transmitting a logic high. To compensate for these power up delays, preferably the presently preferred transmitter 100 provides a longer initial generating period for the high portion of a bit as needed. To maintain a constant bit time period under this circumstance, preferably the nominal bit time of the low portion of the bit is correspondingly shortened when needed to ensure a substantially constant bit transmission times. Preferably, the presently preferred transmitter examines a transmission buffer 112 resident to the presently preferred microprocessor 104 prior to transmitting a bit. A previous bit, a current bit, and a next bit are used to calculate the appropriate high and low times of a bit. As shown in the truth table below, TP is the nominal bit time, TR is a stretch time compensation, TH is the high time of the bit and TL is the low time of the bit.
VI. Data Transmission
Referring again to
At act 1206, the presently preferred transmission routine calls a rolldata subroutine. Preferably, the presently preferred rolldata subroutine shifts out a first bit. If the bit is a logic one, the carry is also set at act 1206. When the carry is set at act 1208, the presently preferred transmission routine drives the modulating output low for a period “TL” at act 1210. In the presently preferred Manchester encoding, a logic one is translated into a logic zero to a logic one transition near the center of the bit timing period. In other words, a logic one is translated into an upward transition near the center of the bit timing period.
At act 1212 the presently preferred transmission routine calls the presently preferred SwitchManager which controls the switch logic debounce routine. Preferably, the presently preferred SwitchManager determines if a valid switch event occurred and queues a switch command if such event has been detected.
At act 1214 the presently preferred transmission routine drives the modulating output high for a period “TH-TD.” Preferably, this act establishes the upward transition near the bit center time period that identifies a logic one. At act 1216, the presently preferred SwitchManger is called to identify any switch events that may have occurred during the transmission. At act 1218, preferably the previous bit flag is set. At act 1220 the Bits-to-transmit, which is a counter that tracks the number of bits to be transmitted, is decremented. If the Bits-to-transmit is not zero at act 1222, the presently preferred process continues with the calculate bit time subroutine at act 1204. However, if the last bit has been transmitted, the presently preferred transmission routine initiates a delay and clears the output at acts 1224 and 1226. At act 1228, the presently preferred transmission routine ends and the presently preferred transmitter 100 enters a sleep mode.
Preferably, the presently preferred transmission process also transmits logic lows. As seen in
At act 1232 the presently preferred transmission routine calls the presently preferred SwitchManager which controls the switch logic debounce routine. Preferably, the presently preferred SwitchManager determines if a valid switching event occurred and queues a switch command if such event has been detected.
At act 1234 the preferred transmission routine drives the modulating output low for a period “TL-TD.” Preferably, this act establishes the downward transition near the bit center that identifies a logic zero. At act 1236, the presently preferred SwitchManger is called to detect any switch events that may have occurred during the transmission. At act 1238, preferably the previous bit flag is cleared. At act 1220, the Bits-to-transmit is decremented. If the Bits-to-transmit is not zero at act 1222, the presently preferred process continues with the bit time subroutine at act 1204. However, if the last bit has been transmitted, the presently preferred transmission routine initiates a delay and clears the output at act 1224 and 1226. At act 1228, the presently preferred transmission routine ends and the presently preferred transmitter enters a sleep mode.
The presently preferred Remote Keyless Entry System embodiments described above utilize a timing circuit 106 that is a unitary part of a microprocessor 104 or micro-controller. While preferably implemented in about the three hundred and fifteen-megahertz United States frequency band, other presently preferred Remote Keyless Entry System embodiments can also be implemented including those operating in about the four hundred and thirty three megahertz European frequency band. Preferably, the timing circuit 106 comprises an array of capacitors selected by switches controlled by the contents of the oscillator calibration register. Alternatively, any frequency dependent components unitary and selectable by hardware or software coupled to or unitary with a microprocessor or micro-controller can also be used.
VII. Operation
In operation, the presently preferred transmitter 100 utilizes algorithms that avoid frequency discontinuities and compensate for voltage and temperature variations. In a first presently preferred algorithm, the K-factor is constant after calibration and is used to avoid frequency discontinuities. In this presently preferred algorithm, the K-factor tracks the number of adjustable instructions that must be executed to maintain a substantially constant bit time period. The K-factor is preferably an integer constant.
In a second presently preferred algorithm, the output frequency of the presently preferred timing circuit 106 is adjusted for voltage and temperature variations. In this presently preferred algorithm, a coarse frequency adjustment is made when the presently preferred microprocessor 104 monitors the presently preferred transmitter 100 initial operating voltage. Preferably, the initial operating voltage is cross referenced to an initial frequency value retained in the presently preferred memory 106. The second presently preferred algorithm then performs a temperature compensation that finely adjusts the output frequency of the presently preferred timing circuit 108. Preferably, the temperature compensation is derived through a comparison of memory write times. This presently preferred approach compares a write time to referenced write times resident to a table retained in memory 108. Preferably, any differences between these write time values generate a temperature compensation that compensates for frequency drift caused by temperature changes. In alternative preferred embodiments, any temperature sensing method or apparatus can be used that is independent of the presently preferred timing circuit.
The above-described embodiments are not limited to the above described reference values or coding methods. Moreover, although the above-described presently preferred embodiments were implemented using a Microchip HCS1365 available from Microchip Technology Incorporated of Chandler, Ariz. other microprocessors and/or controllers can also be used. Furthermore, the above-described calibration processes need not include all of the above-described acts. Many portions of the calibration processes can be excluded or executed separately including, for example, the process of checking the radio frequency format in a digital format, the process of validating current draw in a sleep and/or operating mode, the process of switch debouncing and message queuing during data transmission, and the process of calculating a stretch time or radio frequency compensation.
From the foregoing detailed description, it should be apparent that the presently preferred transmitter 100 can be integrated within or can be a unitary part of a key fob, access card, or any other device. Moreover, when the presently preferred embodiment is a part of a hands free apparatus, system and/or method, the process of switch debouncing and message queuing may not be needed as the presently preferred hand free embodiment may not be activated by a switch or a mechanical movement. It should be further noted that although the above-described presently preferred embodiments can be used or integrated with a vehicle, these embodiments can also be used with many other devices, structures, and technologies.
While various embodiments of the invention have been described, it will be apparent to those of ordinary skill in the art that many more embodiments and implementations are possible that are within the scope of this invention. Accordingly, the invention is not to be restricted except in light of the attached claims and their equivalents.
The following and commonly assigned U.S. patent applications have been filed on the same day as this application. Each of these applications relate to and further describe other aspects of the presently preferred embodiments disclosed in this application and are incorporated by reference in their entirety. U.S. patent application Ser. No. 09/967,488, “Apparatus and Method for Calibrating a Timing Circuit in a Remote Keyless Entry System Using Programmable Commands,” filed on Sep. 28, 2001, and is now U.S. Pat. No. 6,643,598. U.S. patent application Ser. No. 09/967,300, “Apparatus and Method for Timing an Output of a Remote Keyless Entry System,” filed on Sep. 28, 2001, and has been published as United States Publication Number 2003/0063012.
Number | Name | Date | Kind |
---|---|---|---|
5436897 | Cook | Jul 1995 | A |
5583819 | Roesner et al. | Dec 1996 | A |
5696485 | Treharne | Dec 1997 | A |
5828316 | DiCroce | Oct 1998 | A |
5838257 | Lambropoulos | Nov 1998 | A |
5912632 | Dieska et al. | Jun 1999 | A |
5952933 | Issa et al. | Sep 1999 | A |
6034593 | Chase et al. | Mar 2000 | A |
6064705 | Zalud et al. | May 2000 | A |
6172579 | Dacus et al. | Jan 2001 | B1 |
6396389 | Nakano et al. | May 2002 | B1 |
6570486 | Simon et al. | May 2003 | B1 |
6617961 | Janssen et al. | Sep 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
20030063012 A1 | Apr 2003 | US |