The present disclosure relates generally to methods and devices for driving an LED array. More particularly, this disclosure relates to methods and devices that enable extended grayscale values for LED display panels.
Modern LED display panels require higher grayscale levels (i.e., grayscale values, grayscale) to accomplish higher color depth and higher visual refresh rate to reduce flickering. For example, a 16-bit grayscale for a RGB LED pixel may allow 16 bit levels (216=65536) for R, G, B LEDs respectively. Such a RGB LED pixel is capable of displaying a total of 655363 colors. One method commonly employed to adjust LED grayscale is PWM (Pulse Width Modulation). Simply put, PWM turns an LED ON or OFF according to the width of the signal pulse (i.e., pulse duration or pulse width). The ratio between the on time and the off time in turn determines the brightness of the LED. A different ratio represents a different grayscale. Configurations and operations of LED display systems, including LED topology, circuitry, PWM schemes and PWM engines are explained in detail U.S. Pat. No. 8,963,811 B2, filed Sep. 21, 2011.
Nowadays most of LED displays on the market has a 16-bit grayscale range, which is not sufficient to emulate the full range of brightness visible to human eyes. For example, the state-of-art LED display has a brightness range of from 0.1 Nits to 1,700 Nits. It is desirable to have a display that has a wider brightness range, e.g., one emitting light as bright as 10,000 Nits and as dim as 0.005 Nits. Therefore, methods and apparatus are needed to extend the brightness range of the LED display.
In one embodiment, there is provided an LED display system with an increased dynamic range. The LED display system includes a plurality of LEDs arranged into an LED array and a driver circuit configured to drive the array of LEDs. The LEDs (or LED pixels) can be either RGB LEDs or single color LEDs. The driver circuit includes a PWM engine, an adder (i.e., an adder circuit), an accumulator (e.g., a register), a multiplier (e.g., a binary multiplier circuit), and a frame buffer. The frame buffer may include a transmitter and one or more memories. The PWM engine receives PWM data from the frame buffer and generates a plurality of PWM pulses (or simply “pulses”) to drive the LED array.
During operation, the multiplier multiplies an image data of a first bit depth (PWM) with a multiple (M) to produce an input data (PWM_M) having a second bit depth. The multiple has an integer section (MI) of one or more bits in length and a fraction section (MF) of one or more bits in length. The input data has an integer section (PWM_MI) and a fraction section (PWM_MF). The adder adds a value of PWM_MF of a current input data with a value of a remainder in an accumulator. The driver circuit operates to update the remainder to equal the sum of the addition. The driver circuit further operates to subtract integer one from the sum of the addition and update the remainder in the accumulator to equal a result of the subtraction when the sum of the addition equals to or is larger than integer one, and add integer “1” to a bit in PWM_MI. The value of PWM_MI is sent to the frame buffer, which provides PWM data to the PWM engine to generate PWM pulses.
In one embodiment, the bit in PWM_MI that receives integer “1” from the adder is specifically designated for the receiving function and has a default value of zero. The adder fills the bit with integer “1” regardless of the current value stored in the bit.
In another embodiment, the PWM engine generates PWM pulses in a way in which a number of pulses are generated for each non-zero bit in PWM_MI and the number of pulses is in accordance with the designated value of the non-zero bit, no pulse is generated for each bit in PWM_MI that carries integer zero, and no pulse is generated for each bit in PWM_MF regardless of the value in each bit of PWM_MF.
In still another embodiment, there is provided a method for increasing dynamic range of an LED display. The method includes the steps of multiplying an image data of a first bit depth (PWM) with a multiple (M) to produce an input data (PWM_M) having a second bit depth, wherein the multiple has an integer section (MI) of one or more bit in length and a fraction section (MF) of one or more bit in length, wherein the input data has an integer section (PWM_MI) and a fraction section (PWM_MF); conducting an addition operation on a value of PWM_MF of a current input data and the value of a remainder in an accumulator, when a sum of the addition operation is less than one, updating the remainder to equal the sum of the addition; when the sum of the addition equals to or is larger than integer one, subtracting integer one from the sum of the addition and updating the remainder to equal a result of the subtraction, and filling a bit in PWM_MI with integer one; and sending the value of PWM_MI to a frame buffer. The frame buffer provides PWM data to the PWM engine for generating PWM pulses that drives the LED array.
In another embodiment of the method for increasing dynamic range of an LED display, the step of filling the bit in PWM_MI with integer one includes filling the bit with integer one regardless of the current value stored in the bit. The bit is reserved for receiving integer one from the addition operation in the case of when the sum of addition equals to or is larger than integer one, otherwise the value of the bit remains to be zero.
In another embodiment of the method for increasing dynamic range of an LED display, the PWM engine generates PWM pulses in a way in which a number of pulses are generated for each non-zero bit in PWM_MI wherein the number of pulses is in accordance with the designated value of the non-zero bit, no pulse is generated for each bit in PWM_MI that carries integer zero, and no pulse is generated for each bit in PWM_MF regardless of the value in each bit of PWM_MF.
The teachings of the present disclosure can be readily understood by considering the following detailed description in conjunction with the accompanying drawings.
The Figures (FIG.) and the following description relate to the embodiments of the present disclosure by way of illustration only. It should be noted that from the following discussion, alternative embodiments of the structures and methods disclosed herein will be readily recognized as viable alternatives that may be employed without departing from the principles of the claimed inventions.
Reference will now be made in detail to several embodiments of the present disclosure(s), examples of which are illustrated in the accompanying figures. It is noted that wherever practicable similar or like reference numbers may be used in the figures and may indicate similar or like functionality. The figures depict embodiments of the present disclosure for purposes of illustration only. One skilled in the art will readily recognize from the following description that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles of the disclosure described herein.
One aspect of the embodiment according to the current disclosure is illustrated in
In the embodiment of
In a different implementation, if the fraction number in all the image frames is ½ (value in Bit 2 of M is 1), one pulse is displayed every other frame. If the fraction number in the all image frames is ¼ (value in Bit 1 of M is 1), one additional pulse is displayed every 4 frames. If the fraction number in the all image frames is ⅛ (value in Bit 0 of M is 1), one additional pulse is displayed every 8 frames. Note that in other data arrangements of the fraction section in the image frames, the fraction number in the image frames can be the same or different and could be any fractions such as ½, ¼, ⅛, and 1/16, etc. For example, if the fraction number in the image frames is 1/16, one additional pulse is displayed every 16 frames. The even spreading of one pulse across multiple frames increases the granularity of the gray of the image illuminated by the array of LEDs.
Frame #2 has a fraction value of ½ (0.100 in binary format). When the fraction value is added to ¾ stored in the accumulator 203, the outcome is 1¼. Therefore, integer “1” is subtracted from the accumulator so that the remainder in the accumulator 203 is ¼ (0.010 in binary format) while the integer “1” as a carry-out value that is used to populate a carry-out bit 202 in the integer section of PWM_MI.
Frame #3 carries a fraction section with a value of ½ (0.100 in binary format), which is added to ¼ remaining in the accumulator 203 to produce a value of ¾ (0.110 in binary format) in the accumulator 203 for Frame #3. Since Frame #4 has a fraction value of 0 (0.000 in binary format), adding the fraction value of 0 to the remaining value in the accumulator 203 does not change the remaining value in the accumulator 203. Therefore, the remaining value in the accumulator 203 when Frame #4 is being processed remains ¾ (0.110 in binary format).
Frame #5 has a fraction value of ⅞ (0.111 in binary format), and adding this fraction value to the remaining value in the accumulator 203—¾ (0.110 in binary format) yields a value of 1⅝. Therefore, integer “1” is subtracted from the accumulator so that the remainder in the accumulator is ⅝ (0.101 in binary format), while the integer “1” as a carry-out value to populate the carry-out bit 202 in the integer section of PWM_MI.
Frame #6 has a fraction value of ⅛ (0.001 in binary format), which is added to the remaining value in the accumulator—⅝ (0.101 in binary format) to yield a value of ¾ (0.110 in binary format). Frame #7 has a fraction value of ½ (0.100 in binary format). Adding this fraction value to the remaining value in the accumulator—¾ (0.110 in binary format) yields a value of 1¼. Accordingly, integer “1” is subtracted from the accumulator 203 so that the remainder in the accumulator is ¼ (0.010 in binary format), with the integer “1” as a carry-out value that is used to populate the carry-out bit 202 in the integer section of PWM_MI. Since Frame #8 has a fraction value of 0 (0.000 in binary format), adding the fraction value of 0 to the remaining value in the accumulator 203 does not change the remaining value in the accumulator 203.
As shown in the above description and in
It is noted that, although both
Specifically,
In addition to the five fraction sections of a new frame,
Taking the addition operation (symbolized by 421) upon the data stored in 401 and 406 as an example, the addition operation is conducted in the accumulator 406 corresponding to LED #1 yields (symbolized by 422) a value of ⅜ (“0.011” in binary format) (⅜+0=⅜). This value is represented as 0.011 in binary format and used to replace the value of 0.000 in 416 (note, now the 416 reflects of the state of the accumulator after the addition operation), and the corresponding carry-out bit 411 does not receive a carry-out value of “1” and thus remains “0”. Similarly, the addition operations upon the data stored in 402 and 407 as well as the addition operations upon the data stored in 405 and 410 yield a value less than “1”. As such, even though the accumulators 407 and 410 bits are updated with the newly calculated fraction values “⅝” (“0.101” in binary format), “¾” (“0.110” in binary format), respectively. Their corresponding carry-out bits, 412 and 415, respectively, do not receive a carry-out value “1” and thus have their default values “0” remained.
Taking the addition operation upon the data stored in 403 and 408 as another example, the addition operation conducted in the accumulator 408 corresponding to LED #3 yields a value of 1⅜ (1.101 in binary format) (⅞+¾=1⅜), and the remaining value, after subtracting the value “1” (which is advanced to the carry-out bit 413) from the yield, is represented as “0.101” in binary format and used to replace the value of “0.110” in 408. Thus, the corresponding carry-out bit 413 receives a carry-out value of “1”. Similarly, the addition operation upon the data stored in 404 and 409 yields “1.001”, a value larger than “1”, causing the corresponding carry-out bit 414 to receive a carry-out value “1” and updating the fraction section of the new frame data 419 with “0.001” (the remaining value after the addition's yield is subtracted with “1”).
The time sequence of the above-described events represented by T0, T1, and T2 indicates that at the time of T0, accumulators 406, 407, 408, 409, and 410 each holds its current values (“0.000”, “0.001”, “0.110”, “0.011”, and “0.101”, respectively). At T1, the five fraction sections of the image data of the five LEDs (401, 402, 403, 404, and 405) become available, and the outcome of the addition operations are produced at T2.
As described in
Panels 509 and 510, as two separate and collaborating parts of Frame Buffer 512, are schematic diagrams representing an array of image data for an LED, in which, each LED has a 3-bit long accumulator and a 19-bit long PWM_MI. It is noted that in this embodiment, for each LED, its PWM_MF is not stored in the PWM Memory in 509 or 510, but rather is cumulatively stored in the accumulator of the LED. As shown in
In one embodiment, the Frame Buffer 512 is arranged to be bisected as ping memory 509 and a pong memory 510. The ping memory 509 stores an array of 20 bits long PWM_MI data (each of which serves one LED), and an array of 3 bit long accumulator data (each of which serves one LED as well). Likewise, in terms of data arrangement, the pong memory 510 stores an array of 20 bit long PWM_MI data (each of which serves one LED), and an array of 3 bit long accumulator (each of which serves one LED as well). In fact, the function of the ping memory 509 and the pong memory 510 are different. In one particular frame time, the PWM memory in ping memory 509 is used to trigger the displaying of corresponding LEDs. And, meanwhile, the pong memory 510 is receiving the updated data. Also, the ping memory 509 supplies an array of accumulator data such as 506 to the addition operation 513 upon the PWM_MF 504 (which is the fraction part of the result of the multiplication of new MULTIPLE 501 and a new PWM 502) to yield a carry-out value (if any) stored in 507 and a remaining fraction value in 508. The value stored in the accumulator 508 is then used to update a corresponding accumulator in the pong memory 510, and the value (either “0” or “1”) in the carry-out bit 507 is summed (i.e., binary add) (operation 514) with PWM_MI 505 to produce the extended PWM_MI 511, which is then written to a corresponding PWM memory in the pong memory 510.
When current frame finishes displaying and all new frame data finish transferring and stored in frame buffer, a frame change signal Vsync 515 toggles and the roles of the pong memory 510 and the ping memory 509 reverse. Upon the reversal of the roles, the PWM memory of the pong memory 510 is used to trigger the displaying of corresponding LEDs, and the ping memory 509 is used to receive updated data of the coming frame. In the other words, the pong memory 510 supplies an array of accumulator data such as 506 to the addition operation 513 upon the PWM_MF 504 which yields a carry-out value (if any) stored in 507 and a remaining fraction value in 508. The 508 is used to update a corresponding accumulator in the ping memory 509. The new PWM_MI stored in 505 is added (operation 514) with the carry-out bit 507 from operation 513. The result of addition (514) goes through 511 and is written into a corresponding PWM memory of the ping memory 509. When the frame change signal Vsync 515 toggles again, the roles of the ping memory 509 and the pong memory 510 get reversed again. One skilled in the art would understand that the above-mentioned ping-pong memory arrangement may have variants that carry the principle of using minimal memory footprint to effectively achieve what is intended to achieve by using the memories.
Note that using the fraction number to turn on the LED only when its accumulative value equals or exceeds 1 is also applicable without multiplication between the PWM and the multiple (M). For example, one pulse can be equally dithered into eight frames so that each frame receives ⅛ pulse. The conventional method to put ⅛ pulse in one frame requires 8×CLK speed. In comparison, one pulse in 8 frames need only 1×CLK speed.
Many modifications and other embodiments of this disclosure will come to the mind of one skilled in the art having the benefit of the teaching presented in the forgoing descriptions and the associated drawings. For example, the capacity of image data (PWM), Multiple (M), and extended image data (PWM_M) can be expanded or contracted to fit the need and/or circumstance, the designation of value of each bit in PWM, PWM_M, and M can be altered to suit one's preference, the allocation of bits between the integrate section and fraction section of PWM, M, and PWM_M can be adjust according to technical considerations, the threshold for advancing the sum of the value stored in a PWM_MI and the value stored in an accumulator can be adjusted (in the shown embodiments, the threshold is “1”) to a more nuanced value (such as “1⅛”, “1¼”, “⅞”) to satisfy technical circumstances, an accumulator is implemented in a means other than a register indicated in the description. Such variations are within the scope of this disclosure. It is to be understood that the disclosure is not to be limited to the specific embodiments disclosed, and that the modifications and embodiments are intended to be included within the scope of the dependent claims.
Number | Date | Country | |
---|---|---|---|
63070669 | Aug 2020 | US |