Embodiments of the present invention relate to the field of optical transducer control and, in particular, to the use of delta-sigma signal density modulation for intensity control of light-emitting diodes.
Light-emitting diode (LED) technology has advanced to the point where LEDs can be used as energy efficient replacements for conventional incandescent and/or fluorescent light sources. One application where LEDs have been employed is in ambient lighting systems using white and/or color (e.g., red, green and blue) LEDs. Like incandescent and fluorescent light sources, the average intensity of an LED's output is controlled by the average current through the device. Unlike incandescent and fluorescent light sources, however, LEDs can be switched on and off almost instantaneously. As a result, their intensity can be controlled by switching circuits that switch the device current between two current states to achieve a desired average current corresponding to a desired intensity. This approach can also be used to control the relative intensities of red, green and blue (RGB) LED sources (or any other set of primary colors) in ambient lighting systems that mix primary colors in different ratios to achieve a desired color.
One approach to LED switching is described in U.S. Pat. Nos. 6,016,038 and 6,150,774 of Meuller et al. These patents describe the control of different LEDs with square waves of uniform frequency but independent duty cycles, where the square wave frequency is uniform and the different duty cycles represent variations in the width of the square wave pulses. The Meuller patents describe this as pulse width modulation (PWM).
As illustrated in
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings, in which:
Described herein are methods and apparatus for controlling optical transducers using delta-sigma signal density (DSSD) modulation (also referred to herein as delta-sigma modulation, or DSM). The following description sets forth numerous specific details such as examples of specific systems, components, methods and so forth, in order to provide a good understanding of several embodiments of the present invention. It will be apparent to one skilled in the art, however, that at least some embodiments of the present invention may be practiced without these specific details. In other instances, well-known components or methods are not described in detail or are presented in simple block diagram format in order to avoid unnecessarily obscuring the present invention. Thus, the specific details set forth are merely exemplary. Particular implementations may vary from these exemplary details and still be contemplated to be within the spirit and scope of the present invention.
In one embodiment, a method for controlling an optical transducer includes providing a controllable current to a light-emitting diode and controlling the current with a delta-sigma signal density modulation waveform to select a light intensity output from the light-emitting diode. In one embodiment, an apparatus for controlling an optical transducer includes a controllable current source coupled to a light-emitting diode and a controller coupled to the controllable current source, where the controller is configured to provide a delta-sigma signal density control signal to the controllable current source and where the delta-sigma signal density control signal has a selected signal density to control the luminous flux of the light-emitting diode.
The signal density register 106, which may be any type of register or latch as is known in the art, is programmed with an n-bit binary value on input line 108 having a value between 0 and 2n−1, which corresponds to a signal density between 0 and (2n−1)/2n as described below. Adder 104 is clocked by a clock signal fclock on line 107. Each time adder 104 is clocked, the n-bit value at input A from accumulator 105 is added to the n-bit value at input B from signal density register 106. If the sum of the n-bit values at inputs A and B is less than 2n, the delta output of adder 104 is low (i.e., logical “0”) and the sum is expressed at the sigma output of adder 104 and stored in accumulator 105. If the sum of the n-bit values at inputs A and B is equal to or greater than 2n, the adder overflows and the delta output of adder 104 is high (i.e., logical “1”). The remainder is expressed at the sigma output of adder 104 and stored in accumulator 105. The value stored in accumulator 105 is used as the next value of input A of adder 104 on the succeeding clock cycle. Mathematically, the operation of the adder 104 may be expressed as Σ=modulo[(A+B)/2n] and Δ=integer[(A+B)/2n].
f
OUT=min [SD, (1−SD)]×fclock
where min[a,b] is an operator that selects the lowest value from arguments a and b. For an n-bit DSDS modulator, the minimum non-zero signal density is 1/2n, so that the minimum non-zero output frequency is fOUT
The delta output of adder 104 may be coupled to a controllable constant current source 102 to gate the current through an LED 103. In one embodiment, the constant current source 102 may be on (e.g., supplying a constant current I) when the delta value is high and off when the delta value is low. As a result, the average current through the LED 103 will be equal to the signal density times I. The intensity (illumination flux) of the LED is proportional to the average current. Therefore, the intensity of the LED can be controlled by changing the value in the signal density register 106 (it will be appreciated that in other embodiments, current supply 102 may switch between two non-zero current states).
DSSD modulator 101 may be embodied in a variety of ways. In one embodiment, DSSD modulator 101 may be implemented as a processing device having memory to hold data and instructions for the processing device to generate delta-sigma modulation sequences.
In
The processing device 210 may also include an analog block array (not illustrated). The analog block array may also be coupled to the system bus. The analog block array also may be configured to implement a variety of analog circuits (e.g., ADC, analog filters, etc.) using, in one embodiment, configurable UMs. The analog block array may also be coupled to the GPIO 207.
As illustrated in
Processing device 210 may include internal oscillator/clocks 206 and communication block 208. The oscillator/clocks block 206 provides clock signals to one or more of the components of processing device 210. Communication block 208 may be used to communicate with an external component, such as host processor 250, via host interface (I/F) line 251. Alternatively, processing device 210 may also be coupled to embedded controller 260 to communicate with the external components, such as host 250. Interfacing to the host 250 can be achieved through various methods. In one exemplary embodiment, interfacing with the host 250 may be done using a standard PS/2 interface to connect to an embedded controller 260, which in turn sends data to the host 250 via low pin count (LPC) interface. In another exemplary embodiment, interfacing may be done using a universal serial bus (USB) interface directly coupled to the host 250 via host interface line 251. Alternatively, the processing device 210 may communicate to external components, such as the host 250 using industry standard interfaces, such as USB, PS/2, inter-integrated circuit (I2C) bus, or system packet interfaces (SPI). The host 250 and/or embedded controller 260 may be coupled to the processing device 210 with a ribbon or flex cable from an assembly, which houses the sensing device and processing device.
In other words, the processing device 210 may operate to communicate data (e.g., commands or signals to control the absolute and/or relative intensities of LEDs 103R, 103G and 103B)) using hardware, software, and/or firmware, and the data may be communicated directly to the processing device of the host 250, such as a host processor, or alternatively, may be communicated to the host 250 via drivers of the host 250, such as OS drivers, or other non-OS drivers. It should also be noted that the host 250 may directly communicate with the processing device 210 via host interface 251.
Processing device 210 may reside on a common carrier substrate such as, for example, an integrated circuit (IC) die substrate, a multi-chip module substrate, or the like. Alternatively, the components of processing device 210 may be one or more separate integrated circuits and/or discrete components. In one exemplary embodiment, processing device 210 may be a Programmable System on a Chip (PSoC™) processing device, manufactured by Cypress Semiconductor Corporation, San Jose, Calif. Alternatively, processing device 210 may be one or more other processing devices known by those of ordinary skill in the art, such as a microprocessor or central processing unit, a controller, special-purpose processor, digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA), or the like. In an alternative embodiment, for example, the processing device may be a network processor having multiple processors including a core unit and multiple microengines. Additionally, the processing device may include any combination of general-purpose processing device(s) and special-purpose processing device(s).
DSSD modulator 101 may be integrated into the IC of the processing device 210, or alternatively, in a separate IC. Alternatively, descriptions of DSSD modulator 101 may be generated and compiled for incorporation into other integrated circuits. For example, behavioral level code describing DSSD modulator 101, or portions thereof, may be generated using a hardware descriptive language, such as VHDL or Verilog, and stored to a machine-accessible medium (e.g., CD-ROM, hard disk, floppy disk, etc.). Furthermore, the behavioral level code can be compiled into register transfer level (“RTL”) code, a netlist, or even a circuit layout and stored to a machine-accessible medium. The behavioral level code, the RTL code, the netlist and the circuit layout all represent various levels of abstraction to describe DSSD modulator 101.
It should be noted that the components of electronic system 900 may include all the components described above. Alternatively, electronic system 900 may include only some of the components described above.
While embodiments of the invention have been described in terms of operations with or on binary numbers, such description is only for ease of discussion. It will be appreciated that embodiments of the invention may be implemented using other types of numerical representations such as decimal, octal, hexadecimal, BCD or other numerical representation as is known in the art.
Embodiments of the present invention, described herein, include various operations. These operations may be performed by hardware components, software, firmware, or a combination thereof. Any of the signals provided over various buses described herein may be time multiplexed with other signals and provided over one or more common buses. Additionally, the interconnection between circuit components or blocks may be shown as buses or as single signal lines. Each of the buses may alternatively be one or more single signal lines and each of the single signal lines may alternatively be buses.
Certain embodiments may be implemented as a computer program product that may include instructions stored on a machine-readable medium. These instructions may be used to program a general-purpose or special-purpose processor to perform the described operations. A machine-readable medium includes any mechanism for storing or transmitting information in a form (e.g., software, processing application) readable by a machine (e.g., a computer). The machine-readable medium may include, but is not limited to, magnetic storage medium (e.g., floppy diskette); optical storage medium (e.g., CD-ROM); magneto-optical storage medium; read-only memory (ROM); random-access memory (RAM); erasable programmable memory (e.g., EPROM and EEPROM); flash memory; electrical, optical, acoustical, or other form of propagated signal (e.g., carrier waves, infrared signals, digital signals, etc.); or another type of medium suitable for storing electronic instructions.
Additionally, some embodiments may be practiced in distributed computing environments where the machine-readable medium is stored on and/or executed by more than one computer system. In addition, the information transferred between computer systems may either be pulled or pushed across the communication medium connecting the computer systems.
Although the operations of the method(s) herein are shown and described in a particular order, the order of the operations of each method may be altered so that certain operations may be performed in an inverse order or so that certain operation may be performed, at least in part, concurrently with other operations. In another embodiment, instructions or sub-operations of distinct operations may be in an intermittent and/or alternating manner.
In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative sense rather than a restrictive sense.