This invention relates to Light Emitting Diodes and to apparatus and methods for their control.
The present application claims priority from Australian Provisional Patent Application No. 2006906139 entitled “Light Emitting Diode Driver and Method”.
The entire content of this provisional application is hereby incorporated by reference.
A common requirement for electronic equipment is to have a visual indication on a control device. Such a control device could be a button, lever, knob, or similar, and the visual indication is often used to show the state of whatever is controlled—for example an electrical load being turned on or off, or a door open or closed.
In modern electronic equipment, the visual indication is readily provided by a light emitting diode (LED) which has the advantages of being small, cheap, and a long operating life. Multiple colours may be achieved by making use of several LEDs of different colour—these can even be mounted in the same physical package.
By separate dimming of each component colour, a dual-colour combination LED can be used to mix the two component colours to create additional colours, as perceived by a human observer. More recently, three colour combination LEDs have become available, and some of these include elemental components that emit in the colours Red, Green and Blue. By selective dimming of these components, any colour, including white, can be obtained.
In order to produce any resultant colour, an RGB combination LED needs each of the colour components to have a separate dimmable drive. Whilst LED dimming is straightforward using the well-established method of pulse-width modulation, such a typical combination LED will usually have at least 4 terminals: a common point and a drive input for each of the three colour elements.
Using a single three colour RGB combination LED with a common point and 3 drive inputs is relatively easy to drive to obtain any desired human-perceived colour. For example, a small micro-processor can use 3 separate pulse-width modulated outputs to drive such an indicator. An exemplary arrangement of this application is shown in prior art
In operation, microprocessor 10 generates and transmits control signals to each LED 30 and corresponding colour component 31, 32 and 33 to control the operation of each LED in accordance with a sequence of instructions programmed into microprocessor 10 as will be understood by the person skilled in the art.
As can be seen from
It will be appreciated however, that when many such combination LEDs need to be driven (irrespective of the number and nature of the coloured elements)—potentially all showing separate information (for example colour and brightness) the number of drive signals rapidly increases. For example to drive 10 such RGB combination LEDs would require 30 drive signals. As the number of multi-colour combination LEDs in a product increases, the complexity of wiring these to a controller device increases, as does the complexity of the controlling device. For example, a large number of wiring paths might be needed on a printed circuit board, and a large number of pulse width modulated outputs might be needed on a microprocessor. LED controller devices are currently available that make use of serial data buses—the most notable being the Philips inter-integrated circuit (I2C) bus. Such LED controllers allow a 2-wire control output from a microprocessor to be connected to a LED driver IC, which in turn is connected to one or more combination LEDs. By sending appropriate commands to the I2C driver IC, a suitable colour and brightness can be obtained from the combination LED(s). If the combination LED contains red, green and blue elements, then by appropriate selection of brightness of the elements, any colour can be obtained.
Whilst being an improvement on directly connecting LEDs to a microprocessor, systems using these approaches have a number of deficiencies. These deficiencies include the high cost of the LED driver ICs, the limited addressing range of these bus systems, and the additional need to route power and/or ground separately to the LEDs and the driver IC's—increasing circuit board layout complexity and potentially cost, through the need for multi-layer PCBs. Whilst this limited addressing can be overcome by the use of I2C bridges, this adds extra devices and cost to such an arrangement.
It is therefore an object of the present invention to provide an alternative to existing LED control systems.
According to a first aspect of the present invention, there is provided a communications protocol for use in controlling a plurality of Light Emitting Diodes (LEDs) associated with respective LED drivers, the communications protocol comprising a first Command packet containing at least one instruction for controlling a first of the plurality of LEDs, and at least one subsequent Command packet containing instructions for controlling at least one subsequent LED, connected in series with the first LED.
In one form, the protocol further comprises a START code prior to the first Command packet.
In one form, the respective START codes are provided prior to each subsequent Command packets.
In one form, at least one of the first and subsequent Command packets contains instructions for controlling a plurality of elements within a respective LED.
According to a second aspect of the present invention, there is provided a Light Emitting Diode (LED) driver comprising:
In one form, the LED further comprises means for separating the first Command packet from the signal.
According to a third aspect of the present invention, there is provided a Light Emitting Diode (LED) comprising an LED driver according to the second form of the present invention.
According to a fourth aspect of the present invention, there is provided a device for controlling a plurality of LEDs, the device comprising:
In one form, the means for generating is a microprocessor.
In one form, the first means for receiving and controlling, the first means for separating and the means for outputting comprise an LED driver.
In one form, the LED driver is a microprocessor.
In one form, there is at least one subsequent driver associated with at least one subsequent LED.
According to a fifth aspect of the present invention, there is provided an electronic device comprising:
According to a sixth aspect of the present invention, there is provided a method for controlling a plurality of LEDs, the method comprising:
According to a seventh aspect of the present invention, there is provided a machine readable medium containing machine executable instructions to perform the method of the sixth aspect of the present invention.
FIG. 1—shows a prior art arrangement with 2 RGB combination LEDs connected to a microcontroller;
FIG. 2—shows a first exemplary implementation of an aspect of the present invention in which several LED driver circuits are connected to a single microprocessor output;
FIG. 3—shows an exemplary timing diagram and command sequence that could be applied to the arrangement of
FIG. 4—shows an alternative exemplary timing diagram and command sequence that could be applied to the arrangement of
FIG. 5—shows a second exemplary implementation according to an aspect of the present invention, in which two LED driver circuits are connected to 2 microprocessor outputs;
FIG. 6—shows an exemplary timing diagram and command sequence that could be applied to the arrangement of
FIG. 7—shows a block diagram of an LED driver as shown in
FIG. 8—shows a reference circuit diagram of the LED driver of
FIG. 9—shows a block diagram of an LED driver as shown in
FIG. 10—shows a circuit diagram of an exemplary embodiment of the master section of the arrangement shown in
FIG. 11—shows a circuit diagram of an exemplary embodiment of the driver section of the arrangement shown in
Microprocessor 10 can be any microprocessor, from any manufacturer, that is capable of transmitting a data stream out of a single output—a technique commonly referred to as “bit bashing”. Such microprocessors are readily available from many manufacturers, in an almost infinite variant of capability variations. Suitable microprocessors are available from manufacturers including Atmel, Texas Instruments, Zilog, Freescale, ST, and many others.
According to an aspect of the present invention, microprocessor 10 generates a control signal and transmits this along output 11 to an input 21 of the LED driver 20.
As will be described in more detail further below, the signal generated by microprocessor 10 consists of a series of Command packets, each intended for one of the LEDs needed to be controlled by microcontroller 10. Driver 20 accepts the signal, and strips off (or separates) the first Command packet in the signal or data stream, and outputs the remainder of the signal or data stream via output 22. The remainder of the signal is then input into the input 21′ of the next LED driver 20′, which then strips off the next Command packet and outputs the remainder of the signal via output 22′. The signal continues to travel from one LED driver to the next, until all Command packets have been stripped off or separated.
The Command packet for each LED contains information to allow each LED driver 20 to drive each of the red (31), green (32) and blue (33) light components of respective LEDs.
In one form, the communication protocol includes a START code indication, followed by one or more subsequent Command packets. The first Command packet is applied to the first LED driver circuit that the signals reach after the controlling device, and is removed from the stream. Everything after the first Command packet is then passed out of the first LED driver circuit to the second LED driver circuit and so on, as described above. Each LED driver circuit knows to expect a new Command packet when it sees the START code. To ensure that the START code is passed along, each LED driver circuit can either re-generate the START code, as shown in
In one form, the LED driver circuit 20 has the function of accepting in its Command packet a setting of the brightness of each of the colour elements of its attached combination LED.
By placing the LED driver circuits in a sequential cascade arrangement, there is no need to address information to each circuit—instead, addressing will be achieved by the order of the electrical interconnection. Thus, for example, the first Command packet will be accepted by the first LED driver circuit (and subsequent Command packets are simply passed out to the next one in the line). Similarly the second LED driver circuit, not seeing the Command packet that was removed by the first LED driver circuit, will accept the second Command packet transmitted, and pass on any that follow. This process is repeated until the last LED driver circuit is reached.
One suitable method of generating the START code is to encode the Command portions using “bit-stuffing”, and use a coding violation as the START code—a technique which is well established in the prior art. Another possible method is to transmit the Command portion as a stream of asynchronous serial data bits, and to transmit a “Break” symbol as the START code. Whilst these are two suitable methods, there are many others that provide the same behaviour.
Following the START code 110, when present, is the first Command 120. This Command contains control information for the first LED driver 20 to control the various elements of the LED 30 to which it is connected (see
The signal may contain as many Commands as there are LED drivers, or may contain more or less, depending upon the required function of the LEDs to be controlled. For example, if there are more Commands than LEDs, the extra Commands could be simply ignored. If there are fewer Commands than LEDs, either the extra LEDs may not be provided instructions, or the extra LEDs may perform the same function as the last LED which had a specific Command, or could be otherwise connected to previous LEDs to perform the same function as those.
In line B of
The structure of each Command will be tailored for the required operation of each individual LED 30. In one example, the structure of the Command can be a set of binary coded brightness levels for each individual LED. For RGB LEDs, the Command might comprise typically between 4 and 8 bits to encode the brightness levels of the Red, Green, and Blue component LEDs. Any precise ordering or encoding of these brightness levels is unimportant, provided it is applied consistently between the microprocessor 10 and all LED driver circuits.
In this manner, a single microprocessor could drive a single combination LED, or any other number, without additional hardware interconnections being required to the microprocessor. In another form, this arrangement could be used to drive two or more LEDs having only one colour component, or having any number of colour components. In some forms, the LEDs driven could have varying numbers of colour or other control components, for example, the microprocessor might set a flash pattern on a LED, or combination LED, by setting a flash rate, or setting periods of time for a LED or LED components are to be switched on and off.
For example, a system may have 10 LEDs, 5 of which may be single colour components, 2 may be 2-colour components and 3 may be 3-colour components. Of course the number of controllable components within an LED need not be restricted to 3, but could be any number as may be required for the particular application.
One example of a structure of a Start bit used as the Start code, is 1440 us wide, with a low for 960 us and a high pulse for 480 us. A data bit definition for the Command packets could be “Bit 0” having 60 us width with a 20 us low and a 40 us high pulse. The “Bit 1” definition could have a 60 us width with 40 us low and 20 us high pulse. Such coding is known as Manchester coding and is well known to the person skilled in the art. Of course, any other form of suitable coding may also be used.
In generating a signal according to this aspect of the invention, the microprocessor does so in accordance with a software program. An example of a suitable program for controlling five LEDs, 2 of a single colour component and 3 of 3 colour components is shown in the following pseudo-code:
In an alternative form of the present invention, the signal generated by the microprocessor 10 need not have a START code embedded therein. In this case, two microprocessor outputs may be used, the first such output being used to signal the start of a new command stream, and the second such output being used to encode the stream of Commands being sent to each of the driver circuits in turn. Such an encoding of the Commands could comprise digital data, typically as a stream of binary digits (bits).
In this arrangement, LED drivers 20, 20′ . . . will have a third input 23, for receiving the START code from microprocessor 10.
From block 26, the remaining Command packets are passed through to data output 22. If the START code is to be regenerated and passed through to subsequent drivers, this is done at block 35 and provided to output 22 with the remaining Command codes from block 26.
The START code and remaining Command packets are then sent to subsequent drivers via output 22.
The arrangement of
In use, a circuit will be built up using a plurality of drivers 20 as shown in
In another aspect of the invention, there is provided a method of controlling a plurality of LEDs. The first aspect of the method provides for the generation of a signal or data stream according to the protocol described above. In particular, the method includes generating the signal or data stream by generating a Start code, generating a first Command packet, generating at least one subsequent Command packet and then outputting the signal. A further aspect of the method includes receiving the data stream or signal, separating the first Command packet from the data stream or signal to provide a remaining data stream or signal, controlling a first LED in accordance with instructions in the first command packet and outputting the remaining data stream or signal. The remaining data stream or signal is then processed in the same way with respect to the at least one subsequent Command packet.
In another aspect, the present invention provides computer executable instructions which cause a computer to perform the various steps of the methods described herein. In particular, the computer executable instructions cause the computer (such as microprocessor 10) to execute the steps of generating a first Command packet containing at least one instruction for controlling a first of the plurality of LEDs, and generating at least one subsequent Command packet containing instructions for controlling at least one subsequent LED, connected in series with the first LED. In another form, the computer executable instructions cause the computer to also generate a START code and insert this in a data stream in front of the Command and subsequent Command packets. In another form, the computer executable instructions cause the computer to generate separate START codes prior to each of the Command and subsequent Command packets.
In another aspect, the computer executable instructions also cause a computer to perform the steps performed by the driver 20. As described with reference to
In one form, the computer executable instructions may also cause the computer to detect a START code in the data stream, and either pass that START code through and output it with the at least one subsequent Command packet or generate a new START code and output that with the at least one Command packet.
In another aspect of the invention, there is also provided a machine readable medium containing the machine executable instructions described above. Such a machine readable medium includes the memory on the microprocessor 10, or other, separate memory medium, including a CD, a DVD, a Flash drive or other portable memory medium.
In one embodiment, the LED driver circuit could be implemented as an integrated circuit, using a suitable semiconductor technology such as but not limited to silicon. A variation of this embodiment would be to attach and integrate the circuit with an LED device. In one example, this could be an LED with 3 primary colour LED elements. In such an embodiment the current limit resistors may be integrated, or replaced by a transistor based current limiting arrangement, both techniques being well established.
In such an embodiment, which made use of a single control signal from a microprocessor, the completed packaged integrated driver circuit and LEDs would have four electrical connections comprising a power input, a power return (or ground), a data in signal, and a data out signal. An embodiment making use of two outputs from microprocessor would include a fifth electrical connection used to indicate the start of a new stream of Commands.
In one form the microprocessor 10 would transmit the Command stream at a rate of at least 100,000 bits/second. Such a rate would allow the colour and brightness of 10 RBG LEDs to be completely updated in less than 3 milliseconds. Naturally, operation at even faster speeds would be straightforward and yield commensurately lower update times. Naturally, where rapid update or only a small number of LEDs is to be controlled, a lower rate would also be suitable
This arrangement has the advantages that it allows any number of combination LEDs to be driven without need for special expansion devices when an addressing range is exceeded; it allows a small number of drive signals from the controlling device; and it offers the benefit of integrating such a LED driver circuit into the same component package as the combination LED. Integration of the driver circuit into the LED package minimises the overall cost, and dramatically reduces the number of electrical interconnections between the driver IC and the colour elements of the combination LED.
The various aspects of the present invention may be used in any number of electronic devices that have LEDs as part of their circuitry. This includes entertainment devices such as televisions, digital set-top boxes, sound systems, DVD players, CD players, remote control units. It also includes computers and computer peripherals, and displays for vehicles and other devices. The various aspects of the present invention can also be applied to electronic devices that have not yet been invented at the time of filing the present application.
It will be understood that the above has been described with reference to particular embodiments and that many variations and modifications may be made within the scopes of the different aspects of the present invention.
Throughout the specification and the claims that follow, unless the context requires otherwise, the words “comprise” and “include” and variations such as “comprising” and “including” will be understood to imply the inclusion of a stated integer or group of integers, but not the exclusion of any other integer or group of integers.
The reference to any prior art in this specification is not, and should not be taken as, an acknowledgement of any form of suggestion that such prior art forms part of the common general knowledge.
Number | Date | Country | Kind |
---|---|---|---|
2006906139 | Nov 2006 | AU | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/AU2007/001697 | 11/5/2007 | WO | 00 | 12/15/2009 |