With the proliferation of light-emitting-diode (LED) lamps, as well as other types of lamps, there are many applications which include dimming the lamps and changing the color of the lamps. For example, it is often desirable for LED lamps in residential and commercial applications to be dimmable (i.e., have an adjustable brightness). Additionally, it may be desirable for LED lamps to have the capability to change colors when used in instrumentation, user interface displays, and other information-related applications. Further, display screens for information or entertainment applications make use of LED lamps that dim and/or change colors.
In some applications, drivers, which may be switch-mode drivers, linear drivers, or the like, are used to control the current to the lamp. In such setups, the average current, and therefore the brightness of the lamp, can be controlled based on receiving a control signal at the enable input of the driver. Often, these drivers have a limited input bandwidth, where the enable signal is not allowed to change quickly, the driver needing a minimum time to stabilize at each input level (e.g., on-time and off-time) between switching. For example, some drivers have a minimum stable time of 10 microseconds, or the like. This minimum stable time can be longer for high power LED lamp drivers.
Additionally, many control systems that feed a binary control signal to the drivers operate at much higher frequencies, often causing electro-magnetic compatibility (EMC) issues for the associated devices. On the other hand, the bit rate for a lamp control system needs to be high enough to help the human eye low-pass filter the lamp output, to avoid the appearance of lamp flickering. In other words, the bit rate needs to be higher than the flicker fusion threshold so that the light stimulus appears steady to the human eye due to persistence of vision. Further, a sufficiently high bit rate ensures that the system has an adequate overall bandwidth. In some applications, each of these requirements conflict with one another.
The detailed description is set forth with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items.
For this discussion, the devices and systems illustrated in the figures are shown as having a multiplicity of components. Various implementations of devices and/or systems, as described herein, may include fewer components and remain within the scope of the disclosure. Alternately, other implementations of devices and/or systems may include additional components, or various combinations of the described components, and remain within the scope of the disclosure.
Representative implementations of devices and techniques provide a bit packing arrangement for a binary control signal. The control signal may be used with a driver to vary the intensity of a lamp, change the color of the lamp, and the like. For example, multiple control signals may be used to vary the intensity of multiple components of a lamp concurrently, thereby changing the overall color and/or brightness of the lamp. The bit packing arrangement provides a reorganized (i.e., packed) signal to the driver, that is compatible with the driver and the system, and carries the information of the input control signal.
In an implementation, a control signal in the form of a bit stream having a first rate of change is received at a bit packer. A packed control signal based on the bit stream is generated and may be output to a driver device, for example. In one implementation, the packed control signal is comprised of packets. The packed control signal has a varying rate of change, where the mean rate of change of the packed control signal is less than the mean of the first rate of change (i.e., the mean of the bit stream rate of change).
Some implementations include multiple channels for controlling several components of a system (e.g., multiple lamp components for individual colors, etc.). Multiple bit packers may be used with multiple control signals, where each control signal channel includes a bit packer. In one implementation, a bit packer outputs a packed control signal via a spread spectrum output.
Various implementations and techniques for a bit packer arrangement are discussed in this disclosure. Techniques and devices are discussed with reference to example light-emitting-diode (LED) lamps, devices, and systems. However, this is not intended to be limiting, and is for ease of discussion and illustrative convenience. The techniques and devices discussed may be applied to any of various lamp device designs, types, and the like (e.g., liquid-crystal-display (LCD), poly-vinyl-alcohol (PVA) display, piezoelectric material display, electron-stimulated lamps, incandescent lamps, electroluminescent (EL) lamps, etc.), as well as other continuously variable control systems that utilize one or more control signals, and remain within the scope of the disclosure.
Implementations are explained in more detail below using a plurality of examples. Although various implementations and examples are discussed here and below, further implementations and examples may be possible by combining the features and elements of individual implementations and examples.
As illustrated in
If included, a dimming engine 102 receives a dimming level value from a user for example, and distributes the dimming level value to each of the channels 104. In alternate implementations, the dimming level may be received from another source, such as from an output of a process, or the like. In some implementations, the dimming level is a binary value, an integer, or other similar value. The dimming level value determines the overall brightness of the lamp.
In an implementation, the relative dimming values of each channel 104 may also determine the color of the lamp 106. For example, each of the channels 104 may represent a color (i.e., red, green, and blue for a three-color/channel lamp). A combination of a greater intensity on one or more of the channels 104 and a lesser intensity on remaining channels 104 results in a particular overall brightness and/or color of the lamp. Subsequently changing the intensity value of one or more of the channels 104 changes the color or overall brightness of the lamp.
In an implementation, each of the channels 104 may include a modulator 108. The modulator 108 is arranged to receive the dimming level value (a.k.a. brightness value, e.g., ch 1 bright, ch 2 bright, ch 3 bright, ch 4 bright) from the dimming engine 102. In an implementation, the modulator 108 converts the brightness value to a high frequency bit stream. The bit streams from the channels 104 are the input signals to the lamp 106. In an implementation, the mean value of a bit stream corresponds to the brightness value at the input of the respective modulator 108. For the purposes of this disclosure, a bit stream may be described as a digital approximation of an analog input. For example, a bit stream may include a digital representation that is proportional to the magnitude of the voltage or current of the analog input, over a selected duration. The digital representation may be expressed in various ways (e.g., base 2 binary code, binary coded decimal, voltage values, electrical or light pulse attributes, and the like).
In one implementation, the modulator 108 is a sigma-delta modulator. Sigma-delta modulated currents from the modulator 108 result in a sigma-delta modulated brightness level at the lamp 106. Since the human eye has a limited bandwidth, it low-pass filters the varying brightness level output by the sigma-delta modulator 108. If the bit rate is sufficiently high, the eye senses the mean brightness of the lamp 106 that is dependent on the signal output from the sigma-delta modulator 108. In alternate implementations, other techniques and/or devices may be used to convert the brightness value output at the dimming engine 102 to an input signal for the lamp 106. Further, in alternate implementations, the channels 104 may include alternate or additional components to control the brightness and/or color of the lamp 106.
In various implementations, the modulator 108 may be bypassed when a brightness value is output from the dimming engine 102 that represents nearly 0% or nearly 100% of the lamp 106 capacity or control signal level. In that case, a corresponding brightness value signal may be fed to the lamp 106 directly. For example, if the desire is for the lamp 106 to be off (e.g., a control signal value near 0%), there is no need for a modulated signal to be sent to the lamp 106. Rather, an off signal (or the lack of any brightness signal) may be sufficient to turn the lamp off. Conversely, if the desire is for the lamp to be at or near 100%, there is no need for a modulated signal to be sent to the lamp 106 then either. Rather, a signal representing full capacity may be sent directly to the lamp 106, bypassing the modulator 108.
In alternate implementations, various dimming and/or brightness levels may be assigned to be treated as nearly 0% (e.g., 0-3%) and nearly 100% (e.g., 97-100%) for the purposes of bypassing the modulator 108. In other implementations, other values and/or ranges may be used, corresponding to the application.
As discussed above, the lamp 106 may be an LED lamp, another type of lamp, or another controlled system that uses variable control signals. In one implementation, changes to the brightness level value at one or more of the channels 104 changes the brightness and/or color of the lamp 106.
If included, the lamp 106 may use one or more drivers 110 to control one or more lamp strings 112. A driver 110 may be arranged to receive a control signal from a modulator 108, and to control the current to the lamp string(s) 112, based on the control signal. In various implementations, as illustrated in
In alternate implementations, a multi-channel brightness/color control arrangement 100 may include fewer, additional, or alternate components.
In an example, the control system driver 110 receives the packed control signal from the bit packer 202 and controls the intensity of a variable load, such as the lamp string 112 or the lamp 106, based on the packed control signal. For example, the control system driver 110 may control the brightness, color, and the like, of the lamp 106 or lamp components via the packed control signal. A mean value of the packed control signal may correspond to a brightness level, a color intensity, etc. of the lamp 106 or lamp component(s).
In an implementation, the packed control signal comprises one or more packets. The packets are representative of the information in the bit stream, in a reorganized form. For example, each packet includes a first set of consecutive off-bits and a second set of consecutive on-bits, representing the off-bits and on-bits of the bit stream. In one implementation, either the first set of off-bits has a quantity of off-bits that is equal to a preselected off-value or the second set of on-bits has a quantity of on-bits that is equal to a preselected on-value. Thus, a packet either has a fixed set of off-bits and a variable number of on-bits or a fixed number of on-bits and a variable number of off-bits. The preselected off-value and preselected on-value may be user-selected and/or user-adjusted, and are used to determine the length of the off-time or on-time within packets, thereby influencing the length of the packets, as is discussed further below.
If included, the one or more counters (302, 304) are arranged to receive the bit stream from the modulator 108, for example. In an implementation, the bit stream has a first rate of change (which may be based on a system clock, the modulator 108, or another timing source). The one or more counters (302, 304) count the off-bits and count the on-bits of the bit stream. In an implementation, as illustrated in
The counts of two counters (302 and 304) are shown above the input bit stream. In the illustration, the off-time counter 302 counts with each off-bit (low, zero, etc.) of the binary input bit stream and the on-time counter 304 counts with each on-bit (high, one, etc.) of the binary input bit stream.
In the example shown, the value of ONcmp is 5 and the value of OFFcmp is 100, for example. Accordingly, both counters (302, 304) count until one of the counters (302, 304) reaches its corresponding preselected value (i.e., OFFcmp, ONcmp respectively). In the example shown, the on-time counter 304 reaches a count of 5 prior to the off-time counter 302 reaching 100. At the time the on-time counter 304 has reached a count of 5, the off-time counter 302 has counted to 9. The values for the counts from the counters (302, 304) are (9, 5) respectively at that moment. Those counts may be held in a queue 402 temporarily, and then used to generate a packet as illustrated in
In the illustrated case, the packet contains 9 consecutive off-bits and 5 consecutive on-bits, based on the respective counts of the counters (302, 304). In an implementation, as shown in
In an implementation, the bit packer 202 generates a packet with the off-bits grouped together and the on-bits grouped together. This grouping arrangement allows the input bit stream information (which may be at a high bit rate) to be passed to the driver 110 in a compatible manner (e.g., at an average rate of change that allows the driver 110 to stabilize between switching events). In alternate implementations, the on-bits may be arranged to follow the off-bits in a packet, as shown in
As described above, consecutive or subsequent packets may have random or varying lengths, based on a quantity of bits counted by one counter (302 or 304) when the other counter (304 or 302) has reached its associated preselected value (OFFcmp, ONcmp). This is especially noticeable when the preselected values (OFFcmp, ONcmp) are selected/adjusted to be large. For example, in an implementation, the value of OFFcmp equals 218 and the value of ONcmp equals 39. In that implementation, the range of packet lengths can be from 39 bits (0 off-bits and 39 on-bits) to 256 bits (218 off-bits and 38 on-bits). In alternate implementations, the values of OFFcmp and ONcmp can be various other values, determining a different range of packet lengths.
In an implementation, the rate of change of the packed control signal (e.g., packed bit stream) output by the bit packer 202 is constantly varied and random. This is due to the different varying lengths of consecutive packets that make up the packed control signal. Accordingly, the packed control signal has no regular duty cycle. However, in an implementation, the average rate of change of the packed control signal is less than the average rate of change of the input bit stream. This is because the bit packer 202 groups the off-bits and groups the on-bits to make up the packets, thereby reducing the quantity of switching cycles for the same number of bits.
In one implementation, the varying rate of change of the packed control signal provides a spread spectrum output from the bit packer 202. The spread spectrum output can be viewed as a frequency band with a center frequency. In an implementation, the spread spectrum output lessens, if not eliminates, electro-magnetic compatibility issues among the components of the system.
In an implementation, the preselected values OFFcmp and/or ONcmp may be user-selectable and/or user-adjustable. Selection of the preselected values OFFcmp and/or ONcmp determines how a brightness value is represented by the packet. For example, if all packets were the same (essentially never true), the formula for the brightness level would be: brightness=[ONcmp/(Oncmp+OFFcmp)]×100%.
In an implementation, the brightness (or intensity) level represented by a packet is based on the ratio of off-bits to on-bits. For example, if the value of OFFcmp is 218 and the value of ONcmp is 39, and the packet contains 39 off-bits and 39 on-bits, the brightness level represented is 50% brightness. Fewer off-bits paired with the 39 on-bits means that the packet represents a brighter value and more off-bits paired with the 39 on-bits means that the packet represents a less-bright value.
In one implementation, selection of the preselected values OFFcmp and/or ONcmp also determines a frequency range for the output of the bit packer 202, and adjustment of one or more of the preselected values OFFcmp and/or ONcmp adjusts one or more of the limits of the frequency range of the output. For example, the minimum packet time is: PacketTimemin=ONcmp×(1/fbit), where fbit is the clock determining the bit time (e.g., 40 kHz for a 25 microsecond bit time, etc.). The maximum packet time is: PacketTimemax=[(ONcmp+OFFcmp)×(1/fbit)]. The maximum instantaneous frequency is: fmax=fbit/(ONcmp+1).
To avoid the appearance of lamp 106 flicker, it is not desirable for the average rate of change of the bit packer 202 output to be too low. Accordingly, it is desirable to set the value of OFFcmp at a reasonable value to avoid too low of an output frequency. For example, when the intended brightness (or intensity) of the lamp 106 is very low (5%, for example) a large quantity of off-bits may be counted (and grouped into a packet) before the preselected value (ONcmp) for on-bits is reached. Thus, a reasonable value may be selected for OFFcmp (e.g., 218, etc.) to avoid an overly low output frequency. When the off-time counter 302 reaches 218, for example, a packet is generated using the 218 off-bits and the quantity of on-bits counted by the on-time counter 304. More on-bits coupled to the 218 off-bits in a packet results in a lower frequency (and represents a greater brightness) and fewer on-bits coupled to the 218 off-bits results in a higher frequency (and represents a lesser brightness).
Referring to
If included, an off-generation counter 502 may be arranged to generate the set of consecutive off-bits for the packet, based on receiving the count of the off-time counter 302, for example. If included, an on-generation counter 504 may be arranged to generate the set of consecutive on-bits for the packet, based on receiving the count of the on-time counter 304, for example. Also, if included, an output state device 506 may be arranged to organize the set of consecutive off-bits and the set of consecutive on-bits to form the packet, and to output the packet. The output state device 506 may be arranged to organize the set of consecutive off-bits followed by the set of consecutive on-bits, or vice versa. In one implementation, the output state device 506 may be arranged to organize a packet such that the set of consecutive off-bits is followed by the set of consecutive on-bits for safety protocols, for example (e.g., the packet starts in an off-state), or the like.
In one implementation, the packet generator 308 is arranged to output the packet as discussed above: via another stream (i.e., the packed bit steam, packed control signal) having a variable rate of change with a lesser average rate of change than the first rate of change (i.e., the rate of change of the input bit stream). The variable rate of change is based on at least one of the preselected off-value (OFFcmp) and the preselected on-value (ONcmp). A mean value of the packet is equal to a mean value of the input bit stream.
Referring to
In various implementations, the buffer 306 may have multiple stages (e.g., 4 stages, etc.). The buffer 306 may store several sets or pairs of counts in the multiple stages, based on the speed of the output with respect to the speed of the input of the bit packer 202. In an implementation, the buffer 306 is a first-in-first-out (FIFO) buffer device so that the packets are generated in an order corresponding to the input bit stream. This ensures that changes to the desired brightness/color/intensity of the lamp 106 are carried from the input of the bit packer 202 through to the driver 110 and the lamp 106 (or lamp strings 112).
In various implementations, the bit packer 202, including some or all of its components, may be implemented in hardware devices such as one or more digital logic components (e.g., counters, inverters, flip-flops, state machines, etc.) and the like.
As discussed above, the techniques, components, and devices described herein with respect to the bit packer 202 are not limited to the illustrations in
As discussed previously, multiple bit packer 202 arrangements may be used to provide packed control signals to multiple channels 104 of a lamp 106 (or other control system having multiple control signals).
As illustrated in
As shown in
In alternate implementations, such as the implementation of
In various implementations, additional or alternative components may be used to accomplish the disclosed techniques and arrangements.
The order in which the process is described is not intended to be construed as a limitation, and any number of the described process blocks can be combined in any order to implement the process, or alternate processes. Additionally, individual blocks may be deleted from the process without departing from the spirit and scope of the subject matter described herein. Furthermore, the process can be implemented in any suitable materials, or combinations thereof, without departing from the scope of the subject matter described herein.
At block 802, the process includes receiving a binary signal (i.e., input bit stream) having a first rate of change. In an implementation, the binary signal is received by a bit packer (such as bit packer 202, for example), and may be received from a modulator (such as modulator 108, for example) or another control signal source. In an example, the first rate of change is a high frequency (such as 40 kHz, for example), and may not be fully compatible with the application (e.g., a driver, the EMC standards, etc.) based on the high rate of change.
At block 804, the process includes counting a first quantity of off-bits and a second quantity of on-bits of the binary signal. In an implementation, one or more counters (such as counters 302 and 304, for example) are arranged to count the first quantity of off-bits and the second quantity of on-bits.
At block 806, the process includes comparing the first quantity of off-bits to a preselected off-value (such as OFFcmp, for example) and comparing the second quantity of on-bits to a preselected on-value (such as ONcmp, for example). In one implementation, one or both of the preselected off-value and the preselected on-value are user-selectable and/or user-adjustable.
At block 808, the process includes forming a packet when the first quantity of off-bits equals the preselected off-value or the second quantity of on-bits equals the preselected on-value. For example, when either count (off-bits or on-bits) is equal to the associated respective preselected value, the count of both off-bits and on-bits stops. In an implementation, the counts (i.e., first quantity of off-bits and the second quantity of on-bits) are output to a packet generator (such as packet generator 308, for example), which generates a packet based on the counts (e.g., forms the packet based on the first quantity of off-bits and the second quantity of on-bits).
In an implementation, the packet includes a set of consecutive off-bits having an amount of off-bits equal to the first quantity of off-bits and a set of consecutive on-bits having an amount of on-bits equal to the second quantity of on-bits. In one implementation, the packet comprises the first quantity of off-bits followed by the second quantity of on-bits. In another implementation, the packet comprises the second quantity of on-bits followed by the first quantity of off-bits.
In one implementation, the process includes resetting the first quantity of off-bits and the second quantity of on-bits after outputting the first quantity of off-bits and the second quantity of on-bits to the packet generator. For example, once the counter(s) have output the respective count values to the packet generator, the counter(s) are reset and begin counting off-bits and on-bits of the input bit stream for the next packet.
In another implementation, the process includes temporarily storing one or more pairs of counts, wherein a pair of counts comprises a first quantity of off-bits and a second quantity of on-bits. For example, the pairs of counts may be stored in a storage device (such as buffer 306, for example) having one or more stages.
At block 810, the process includes outputting the packet. For example, the packet may be output to a driver (such as driver 110, for example) to control a lamp (such as lamp 106, for example).
In one implementation, the process includes outputting the packet via a second binary signal (i.e., a packed control signal, packed bit stream) having a constantly varying rate of change and a lesser average rate of change than the first rate of change (i.e., the rate of change of the input bit stream).
In another implementation, the process includes outputting the packet via a spread spectrum output having a frequency range based on at least one of the preselected off-value and the preselected on-value. For example, the spread spectrum output shapes the switching frequency of the output packed control signal, improving EMC properties. In an implementation, the process further includes adjusting an upper limit of the frequency range by adjusting the preselected on-value.
In one implementation, the process includes outputting subsequent packets based on the binary signal (i.e., input bit stream), where the subsequent packets have varying quantities of bits. For example, subsequent packets may have different lengths as discussed above.
In alternate implementations, other techniques may be included in the process 800 in various combinations, and remain within the scope of the disclosure.
Although the implementations of the disclosure have been described in language specific to structural features and/or methodological acts, it is to be understood that the implementations are not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as representative forms of implementing example devices and techniques.