1. Field of the Invention
The disclosure relates generally to remote control systems, and specifically to a universal remote control transmitter that can acquire the transmission frequency and modulation pattern of another transmitter without prior knowledge of these parameters.
2. Background of the Invention
Transmitter-receiver controller systems are widely used for remote control and/ or actuation of devices or appliances such as garage door openers, gate openers, security systems, and the like. For example, most conventional garage door opener systems use a transmitter-receiver combination to selectively activate the drive source (i.e., motor) for opening or closing the door. The receiver is usually mounted adjacent to the motor and receives a coded signal (typically radio frequency) from the transmitter. The transmitter is typically carried by a user and selectively activated by the user to open or close the garage door. These type of remote control systems typically employ VHF/UHF radio frequency transmissions.
In general, a remote control system has a remote transmitter and a receiver coupled to the device, which is to be controlled. When activated, the transmitter emits a modulated signal, which is recognized by the receiver to activate the device. In VHF/UHF-based systems, a transmitter typically emits a pulse-modulated VHF/UHF signal. The signal embodies a modulation pattern as a sequence of “signal on” and “signal off” intervals. The modulated signal emitted by the transmitter is recognized by the receiver. The modulation pattern of remote control systems is typically unique to restrict unauthorized access to the device being controlled.
Different manufacturers of such transmitter-receiver systems generally utilize different transmission protocols or patterns for transmitting the coded signal. Additionally, the manufacturers typically operate the transmitter-receiver systems at different transmission frequencies within the allocated frequency range for a particular type of system. The modulation pattern typically includes two aspects: 1) a device code (equivalent to a device address) for the transmitter and receiver, and 2) a transmission format, i.e., the characteristics of the transmitted signal including timing parameters and modulation characteristics related to encoded data. The transmission pattern used by one manufacturer is usually incompatible with that provided by other manufacturers.
Currently available transmitter-receiver systems typically employ custom encoders and decoders to implement the transmission pattern. These encoders and decoders are fabricated with custom integrated circuits such as application-specific integrated circuits (ASICs). They are fixed hardware devices and allow very limited flexibility in the encoding/decoding operation or in the modification of the encoding/decoding operation.
Thus, in such existing transmitter-receiver systems, it is necessary to know the transmission frequency accepted by the receiver and to match or determine the modulation pattern recognized by the receiver. In a number of transmitter-receiver systems, the modulation pattern is determined by setting a plurality of dual inline package (DIP) switches (or a modulation pattern selection circuit) on the transmitter and by similarly setting a plurality of DIP switches (or a corresponding modulation pattern selection circuit) on the receiver. Once the required frequency and the modulation pattern are defined, a compatible transmitter can be provided to operate with the receiver. The DIP switches or the modulation pattern selection circuit may also be manually reset to match the modulation pattern of signals transmitted by a new transmitter to that of the existing receiver. Alternatively, both the existing receiver and new transmitter can be reprogrammed with a new modulation pattern. However, existing reprogramming techniques require prior knowledge of the transmission frequency and modulation protocol of the existing transmitter. In addition, they can only be implemented in compatible transmitters and receivers using complex circuits.
Embodiments herein disclose a universal transmitter. In one embodiment, the universal transmitter includes an input circuit including an antenna, a central processing unit (CPU) coupled to the input circuit, and a radio frequency (RF) circuit coupled to the CPU. The CPU is operable to generate a plurality of discrete digital outputs, and in response thereto, causes the RF circuit to generate and transmit a local RF signal at a corresponding plurality of discrete scanning frequencies. The input circuit receives the local RF signal and a template RF signal including a target frequency and a modulation pattern, and mixes the local RF signal and the template RF signal and provide a mixed signal. The CPU samples the mixed signal at the plurality of scanning frequencies, and determines the target frequency of the template RF signal in response to the plurality of samples.
Other embodiments are disclosed and claimed herein.
Disclosed herein is a universal transmitter that provides a low-cost remote control transmitter that can be programmed to “learn” the transmission frequency and modulation pattern of any template transmitter. The universal transmitter is then operable to transmit the “learned” modulation pattern and transmission frequency to actuate a remote control receiver operable with the template transmitter. The universal transmitter is capable of recognizing a fixed-code pulse-modulated, frequency shift keying, or other transmission without prior knowledge of the frequency and modulation pattern. That is, the transmitter is universal in that it is capable of transmitting at any frequency that is allocated for remote control devices and is capable of being programmed to generate a modulated signal with any modulation pattern based on any modulation protocol.
The universal transmitter can store the “learned” transmission frequency and modulation pattern of multiple transmitters in non-volatile memory. Thus, multiple programmable switches are provided to allow the universal transmitter to control multiple devices simultaneously. In one embodiment, the universal transmitter includes, among other devices, a micro-controller, oscillator for providing internal timing, memory for storing data representative of a modulation pattern and transmission frequency, input/output circuitry, and a digital to analog converter that controls a voltage controlled oscillator to generate signals over a wide range of frequencies (e.g., between 280 to 450 MHz or other frequency range).
Referring now to the drawings, and in particular to
In a representative utilization, the transmitter 100 is a remote control device which can be used with the receiver 120 as part of a garage door opening system. In this representative utilization, utility device 130 may be the garage door mechanism, including the motor, drive mechanism, lighting apparatus and/or the like. For example, the utility device 130 opens or closes a garage door when activated by receiver 120 upon receipt of the appropriate signal from the transmitter 100. While a garage door opening mechanism is illustrative, many other types of utility devices may be controlled by such remote transmitter-receiver system such as gates, light systems, security systems, etc.
When activated, the programmable transmitter 100 generates a signal 110 having a predetermined transmission frequency and a unique data transmission format, that is, the timing parameters and modulation characteristics related to encoded data are unique to the design of the particular transmitter. The receiver 120 is adapted to receive and decode the signals generated by the transmitter 100 to produce an output signal which is supplied to the utility device 130. In one embodiment, the transmitter 100 and the receiver 120 transmit and receive at a single transmission frequency, using a single data transmission format. In alternative embodiments, multi-format and/or multi-frequency systems may be implemented.
The transmitter 100 and receiver 120 typically have a selectable code (or address) that is set using a plurality of DIP switches in each unit. Identical codes are required for communication between a transmitter 100 and a receiver 120. Setting the DIP switches to identical settings (on or off) in each unit provides identical codes. Communication between the transmitter 100 and receiver 120 is accomplished according to a specific data transmission format which typically is unique to devices provided by the manufacturer of the specific transmitter-receiver system. There are many different transmission formats used by various manufacturers. Exemplary transmission formats are described in U.S. Pat. No. 5,841,390, invented and owned by the inventor and owner of the present application, the contents of which are fully incorporated herein by reference.
Referring to
The DAC 250 includes a resistor network which receives a plurality of inputs from the CPU 210 and provides an analog output voltage to the VCO 260. The output voltage of the DAC 250 dictates the transmission frequency of a signal transmitted by the RF circuit 255.
The transmitter 100 may include “N” switches 230 to allow a user to program the transmission frequency and modulation pattern of up to N different template transmitters. LED indicators 240 provide a visual indication of the operation of the transmitter 100.
In the embodiment shown, the switch array 230 includes four switches S1–S4. Each switch S1–S4 may be programmed to store a unique modulation frequency and modulation pattern of a template transmitter, thereby allowing the universal transmitter 100 to control four different receivers, and thus four different devices. It is to be appreciated that more or less switches may be provided. The CPU 210 is coupled to the non-volatile memory 225. During a learning mode, the CPU 210 stores data values representative of the modulation frequency and modulation pattern “learned” from a template transmitter in the memory 225, and associates the data values with one of the switches S1–S4. During a transmit mode, the CPU 210 retrieves data values representative of the modulation frequency and modulation pattern associated with the actuated switch from memory 225. Data is written into the memory 225 serially via pin PA0, and is read from the memory 225 serially via pin PB5. In another embodiment, instead of storing the modulation frequency of a signal in memory 225, the CPU 210 may store a value or a pointer, which represents or points to a list of predetermined frequency values (e.g., which may be stored in the internal read-only memory of the CPU 210).
The CPU 210 output pins PA0–PA3, PC0–PC4, and PG0 are coupled to the DAC 250, which includes a resistor network. In the embodiment shown, the DAC 250 provides a 10-bit resolution. However, the DAC 250 may be designed to provide a higher or lower resolution. The output of the DAC 250 is coupled to the VCO 260. Depending on the digital voltage level on outputs pins PA0–PA3, PC0–PC4, and PG0, the output of the DAC 250 provides an output voltage between zero and five volts to the VCO 260. The VCO 260 is employed to generate signals having a transmission frequency over a wide frequency range in response to the output of the DAC 250 (e.g., 100 MHz to 1 GHz). In one embodiment, the VCO 260 is controlled to generate signals having a transmission frequency over 280 MHz to 450 MHz. However, it is to be understood that the VCO 260 may generate signals having a transmission frequency over a different frequency range.
The analog output voltage of the DAC 250 controls the capacitance of a varactor diode VD of the VCO 260 to generate the appropriate transmission frequency. Thus, the output frequency of the RF circuit 255 increases or decreases according to the control input voltage from the DAC 250. For example, if the VCO 260 can operate within 280 MHz to 450 MHz, then zero volts on the DAC output can correspond to the VCO 260 generating a 280 MHz signal and five volts on the DAC output can correspond to the VCO 260 generating a 450 MHz signal. When the CPU 210 output pins PA0–PA3, PC0–PC4, and PG0 are zero, the DAC 250 output voltage is zero since no current passes through resistor R20. Therefore, the VCO 260 will provide an operating frequency of 280 MHz. Conversely, when the CPU 210 output pins PA0–PA3, PC0–PC4, and PG0 are all high (five volts), the output voltage of the DAC 250 is 5 volts and the current passing through resistor R20 is 0.5 mA. As a result, the VCO 260 will provide an operating frequency of 450 MHz. To operate the VCO 260 in between 280 MHz to 450 MHz, some of the CPU 210 output pins will be high and some will be low.
The transistor Q7 and the associated capacitors and resistors act as a Colpitts oscillator. A tunable inductor L1 is in series with capacitor C24. The oscillation frequency of the VCO 260 is coupled to an RF power transistor Q8 for transmission. The PB4 output pin of the CPU 210 is coupled to the VCO 260 of the RF circuit 255. When the PB4 output is low, transistor Q7 is off to deactivate the VCO 260. Conversely, when the PB4 output is high, transistor Q7 is on to activate the VCO 260. During transmit mode, the CPU 210 retrieves the ON and OFF intervals, representing the transmission format, from memory 225. The CPU 210 turns Q7 on to activate the VCO 260 during the ON interval, and turns off Q7 to deactivate the VCO 260 during the OFF intervals.
The RF circuit 255 includes a transmitting antenna 265 that operates in conjunction with the VCO 260 and transistor Q7 to generate and transmit signals having a desired transmission frequency and transmission format. In one embodiment, the antenna 265 operates to generate and transmit signals in the frequency range between about 100 MHz to 1 GHz. The antenna 265 may be implemented as a trace on a printed circuit board (PCB) or as a preformed wire that is soldered onto the PCB.
The universal transmitter 100 includes a voltage regulator 270 that receives an input voltage (e.g., 12 volts), and provides a 5 volt regulated output. In an inactive state, where none of the switches S1–S4 are pressed, transistor Q4 is off and de-couples the 12 volt supply from the input of the voltage regulator 270. When one (or more) of the switches S1–S4 is(are) pressed, the base of transistor Q4 drops sufficiently below 12 volts to turn on Q4 and couple the 12 volt supply to the input of the voltage regulator 270. Consequently, the output of the voltage regulator 270 goes from 0 volts to 5 volts. The 5 volt supply is then applied to the components and devices in the universal transmitter 100. Initially, when the output of the voltage regulator 270 goes from 0 to 5 volts, the reset input pin (RES/) of the CPU 210 is low (capacitor C4 has no charge) causing the CPU 210 to be in a reset state. As the capacitor C4 charges, eventually to 5 volts, the reset pin goes high causing the CPU 210 to execute instructions from its internal read-only memory or micro-code. The CPU 210 may perform an initialization routine. Additionally, after power is supplied to the CPU 210, the CPU 210 may apply 5 volts on the PB1 output pin to turn on transistor Q3 and keep transistor Q4 on and thus main power, even if the switches are released prematurely, in order to complete the current operation. Thus, for example, in a transmit mode, if a switch is pressed to transmit a signal (e.g., garage door opener) and the switch is released before the transmitter transmits the signal, the CPU 210 can maintain power to the transmitter until the signal is transmitted, and then remove power by turning off Q3.
Once initialization is complete, the CPU 210 determines which of the switches S1–S4 was pressed by monitoring input pins PA4 to PA7. If a switch is pressed and released before the expiration of a predetermined time period (e.g., 3 seconds), then the universal transmitter 100 will enter a transmit mode to transmit a modulation pattern at a transmission frequency associated with the actuated switch. If a switch is pressed and held for at least the predetermined time period (e.g., 3 seconds), the universal transmitter will enter a “learning” mode to “learn” the transmission frequency and transmission format of a template transmitter.
In the transmit mode, the CPU 210 retrieves data representative of the transmission format (e.g., the ON and OFF intervals) and the transmission frequency, associated with the actuated switch, from the non-volatile memory 225. The CPU 210 then outputs appropriate values (0 or 5 volts) on output pins PA0–PA3, PC0–PC4, and PG0 to the DAC 250. The DAC 250 converts the digital values to an analog voltage (e.g., from 0 to 5 volts). This analog voltage is provided to the VCO 260. The VCO's frequency is adjustable or tunable via the varactor diode VD. The CPU 210 also turns transistor Q7 on and off in accordance with the ON and OFF intervals retrieved from memory 225 to cause the RF circuit 255 to transmit a signal having the transmission frequency and transmission format associated with the actuated switch. Once the signal is transmitted, the CPU 210 may enter the inactive mode by driving output pin PB1 to zero, which turns off transistors Q3 and Q4. Turning off transistor Q4 de-couples the 12 volt supply from the voltage regulator 270 and thus power is removed from the transmitter 100. During transmission, the LED's 240 are switched ON and OFF in accordance with the desired modulation pattern transmitted by the universal transmitter 100.
In the learning mode, the CPU 210, executing internal program code, causes the RF circuit 255 to transmit a signal (hereinafter referred to as the “local signal”) having a scanning frequency ƒs starting from a lowest frequency on a defined spectrum (S) to the highest frequency in the spectrum (e.g., 280 MHz to 450 MHz) at one or more predetermined steps. Most template transmitters in North America transmit signals within the frequency range of 300 MHz to 434 MHz. Therefore, in the current exemplary embodiment, the frequency spectrum is defined from 280 MHz to 450 MHz. It should be noted that a different and/or wider frequency range may be employed. The local signal is received by the antenna 215, which also receives a signal from the template transmitter (hereinafter referred to as the “target signal”). The target signal transmitted from the template transmitter has a particular frequency ƒc (hereinafter referred to as the “target frequency”). The purpose of the scanning frequency ƒs is to locate the target frequency ƒc from the template transmitter. The target signal is defined as V1 while the local signal is defined as V2, and can be expressed as follows:
V1=V1m cos(ωct+φ), and (1)
V2=V2m cos(ωst), (2)
where,
V1 is the transmitted RF signal from the template transmitter,
V2 is the signal transmitted by the universal transmitter 100,
ωc is the reciprocal of target frequency ƒc of the template transmitter (fixed),
ωs is the reciprocal of scanning frequency ƒs (which changes in this exemplary embodiment between 280 MHz to 450 MHz during the learning mode), and
φ is the data signal. It should be noted that the local signal is just a frequency carrier and does not contain a data signal φ.
Both signals (V1) and (V2) are received by the antenna 215 and coupled to the base of the transistor Q5. Transistor Q5 exhibits amplitude-nonlinear behavior, and thus serves as a mixer. Mixing is achieved by the application of two signals to a nonlinear device. The resulting mixed signal can generally be expressed in following form:
where,
Vom, is the output signal from transistor Q5, and provides the sum or difference signal of the target signal (V1) and local signal (V2) after mixing, as depicted in
According to equation (3), the output signal Vom varies according to the reciprocal of the frequencies ωc and ωs. The Vom signal is produced by the intermodulation of the transistor Q5. The scanning frequency ƒs of the local signal increases by predetermined steps. As the local signal (V2) approaches the target signal (V1), the intermodulation amplitude appears and increases until the frequency of both local and source signals are very close, e.g., when
When the frequency of the source signal is substantially the same as the frequency of the local signal (ωc=ωs) the Vom output signal is equal to zero according to equation (3). This is represented by zone III. When no signal is detected, the CPU 210 knows that the target frequency is within zone III, and will continue to search in order to determine the target frequency ƒc.
The process executes blocks 514, 518, 522, 526, 530, and 534 in sequence and the scanning frequency is sequentially increased until a signal, having predetermined signal strength, is detected by the CPU 210 at block 522. The process then moves to block 538 where a determination is made as to whether zone is equal to 4. If not, the process moves to block 542 where a further determination is made as to whether zone is equal to 2. Note that blocks 538 and 542 may be combined in software using a case statement or equivalent. Since zone is still equal to 1, the process moves to block 546. At block 546, zone is set to 2 indicating that zone II has been reached. The process moves to block 534 where the scanning frequency is increased by the predetermined increment (e.g., 5 MHz). Note that a different predetermined increment may be used when the process is in zone II (e.g., 2 MHz). While in zone II, blocks 514, 518, 522, 538, 542, and 534 are executed in sequence (as the signal level detected by the CPU 210 increases) until, at block 522, no signal or appreciable signal is detected by the CPU 210. When no signal is detected, the process moves to block 526. Since zone is equal to 2, the process continues to block 530. Now, since zone is equal to 2, the process moves to block 550.
At block 550, the CPU 210 records the current scanning frequency as ƒ1 as zone III has been reached. At block 554, the process increases the scanning frequency ƒs past zone III. This can be accomplished by increasing the scanning frequency ƒs by some value greater than the width of zone III, which, in the current exemplary embodiment, is 500 kHz. For example, the scanning frequency may be increased by 1 MHz, 2 MHz, 5 MHz, etc. At block 558, zone is set to 4. The process then moves back to block 514 where the CPU 210 causes the RF circuit 255 to transmit a local signal having the new scanning frequency ƒs in zone IV. At block 518, the CPU 210 reads its input pin(s). At block 522, the CPU 210 will detect a signal at its input pin(s) since the scanning frequency ƒs is in zone IV (zone=4), and thus the process moves to block 562 through block 538. At block 562, the scanning frequency is decreased by some predetermined amount, which may be different than the predetermined amount added to the scanning frequency in block 534. In one embodiment, the predetermined amount may be 1 MHz, 2 MHz, etc.
Blocks 514, 518, 522, 538, and 562 are executed in sequence and the scanning frequency is iteratively decreased until no signal or no appreciable signal is detected at the input pin(s) of the CPU 210 at block 522. Now, the process moves to block 526, and since zone is equal to 4, the process continues to block 566. At block 566, the current scanning frequency is recorded as ƒ2, as the right most edge of zone III is reached. Then, at block 570, the process determines the target frequency ƒc, which is somewhere in the region between ƒ1 and ƒ2. In one embodiment, the target frequency ƒc is determined by the following expression:
The process then returns.
Once the target frequency ƒc is determined, the CPU 210 may store the value or data representative of the value in internal random access memory, and proceed with the code format learning process.
Referring to
At block 626, the CPU 210 samples one or both of its input pins PB2 and PC5. In one embodiment, the PB2 input pin is used to sample and detect a first code format (e.g., pulse-modulated) and the PC5 input pin is used to sample and detect a second code format (e.g., frequency shift keying) to account for the different code formats used by garage door openers, car alarms, and other wireless transmitting devices. Note that a single input pin may be used to detect more than one code format. Alternatively, more than two input pins may be used to detect different code formats.
According to the code format in
One or more embodiments may be implemented as a method, apparatus, system, computer program product, etc. When implemented in software, the elements are essentially the code segments to perform the necessary tasks. The program or code segments can be stored in a processor readable medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication link. The “processor readable medium” may include any medium that can store or transfer information. Examples of the processor readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette, a CD-ROM, an optical disk, a hard disk, a fiber optic medium, a radio frequency (RF) link, etc. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc.
While the preceding description has been directed to particular embodiments, it is understood that those skilled in the art may conceive modifications and/or variations to the specific embodiments and described herein. Any such modifications or variations which fall within the purview of this description are intended to be included therein as well. It is understood that the description herein is intended to be illustrative only and is not intended to limit the scope of the invention. Rather the scope of the invention described herein is limited only by the claims appended hereto.
This application is a continuation-in-part of application Ser. No. 09/885,466, entitled “UNIVERSAL TRANSMITTER”, filed Jun. 19, 2001, which is a continuation of application Ser. No. 09/188,648, entitled “UNIVERSAL TRANSMITTER”, filed Nov. 9, 1998, now U.S. Pat. No. 6,249,673, the contents of which are fully incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
4535333 | Twardowski | Aug 1985 | A |
4623887 | Welles, II | Nov 1986 | A |
4626848 | Ehlers | Dec 1986 | A |
4771283 | Imoto | Sep 1988 | A |
4825200 | Evans et al. | Apr 1989 | A |
4878052 | Schulze | Oct 1989 | A |
4905279 | Nishio | Feb 1990 | A |
4959810 | Darbee et al. | Sep 1990 | A |
5227780 | Tigwell | Jul 1993 | A |
5379453 | Tigwell | Jan 1995 | A |
5442340 | Dykema | Aug 1995 | A |
5564101 | Eisfeld et al. | Oct 1996 | A |
5614891 | Zeinstra et al. | Mar 1997 | A |
5619190 | Duckworth et al. | Apr 1997 | A |
5661804 | Dykema et al. | Aug 1997 | A |
5680134 | Tsui | Oct 1997 | A |
5686903 | Duckworth et al. | Nov 1997 | A |
5699054 | Duckworth | Dec 1997 | A |
5699055 | Dykema et al. | Dec 1997 | A |
5790948 | Eisfeld et al. | Aug 1998 | A |
5793300 | Suman et al. | Aug 1998 | A |
5815086 | Ivie et al. | Sep 1998 | A |
5841390 | Tsui | Nov 1998 | A |
5854593 | Dykema et al. | Dec 1998 | A |
5864751 | Kazami | Jan 1999 | A |
5903226 | Suman et al. | May 1999 | A |
6005508 | Tsui | Dec 1999 | A |
6008735 | Chiloyan et al. | Dec 1999 | A |
6021319 | Tigwell | Feb 2000 | A |
6249673 | Tsui | Jun 2001 | B1 |
6265987 | Wang et al. | Jul 2001 | B1 |
Number | Date | Country | |
---|---|---|---|
20020137479 A1 | Sep 2002 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09188648 | Nov 1998 | US |
Child | 09885466 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 09885466 | Jun 2001 | US |
Child | 10051781 | US |