This application claims priority to Korean Patent Application No. 2007-0003262, filed on Jan. 11, 2007, in the Korean Intellectual Property Office, the disclosure of which is incorporated by reference in its entirety herein.
1. Technical Field
The present disclosure relates to a semiconductor device, and more particularly, to a semiconductor device including a correction parameter generator and a method of generating correction parameters.
2. Discussion of the Related Art
A liquid crystal display (LCD) is an electronic device, which converts diverse electronic information generated by various apparatuses into visual information using liquid crystals. The transparency of the liquid crystals change according to an applied voltage. As compared to a conventional cathode-ray tube (CRT) display, the LCD may have a higher resolution, be thinner, and consume less power. However, when displaying moving pictures, the LCD may suffer from time delays caused by changes in molecular arrangements, which occur when an electric field is applied to a liquid crystal material. The time delays may cause blurring or tailing. Liquid crystal molecules in an LCD may move slowly. Overdrive technology may be used to increase the response speed of the liquid crystal molecules by correcting a video signal of the LCD.
In some current overdrive technologies, correction parameters are selected from a look-up table (LUT). The LUT stores correction parameters based on the combination of a pixel value of a previous frame and a pixel value of a current frame. The selected correction parameters are interpolated and a corrected video signal is output as a result of the interpolation. The LUT stores correction parameters, which are determined based on panel characteristics of an LCD and may be obtained through experimentation. The LUT may be stored in memory.
However, memories that store the LUT require a large capacity, for example, 256*256 bytes. Methods for using smaller capacity memories have been proposed. However, when adjacent parameters are selected from the LUT in these methods in which four parameters are simultaneously selected, the parameters may be inadvertently selected again, causing data redundancy or a waste of clock cycles.
According to an exemplary embodiment of the present invention, there is provided a semiconductor device including an address generator and an output unit. The address generator is configured to output a plurality of addresses in response to a first number of most significant bits of a current pixel value and a second number of most significant bits of a previous pixel value. The first number of most significant bits includes a first selection bit and the second number of most significant bits includes a second selection bit. The output unit is configured to determine correction parameters, which respectively correspond to the plurality of addresses, in response to the plurality of addresses. The output unit selects one index pattern from a plurality of index patterns in response to the first selection bit and the second selection bit, and arranges the determined correction parameters into the selected index pattern to output arranged correction parameters. The index pattern may be a pattern that can be generated according to positions of the determined correction parameters in a look-up table including the plurality of indexes.
The output unit may include a memory unit and a parameter arranging unit. The memory unit may be configured to output the correction parameters, which respectively corresponds to the plurality of addresses, in response to the plurality of addresses. The parameter arranging unit may be configured to receive the correction parameters from the memory unit and to arrange the received correction parameters into the index pattern in response to the first selection bit and the second selection bit. The memory unit may include a plurality of memories, each of which stores a plurality of correction parameters according to one index among the plurality of indexes.
The address generator may include an address generation section and a plurality of selectors. The address generation section may be configured to generate a plurality of first addresses based on the first number of most significant bits and the second number of most significant bits. The plurality of selectors may each be configured to transmit one address among the plurality of first addresses to a corresponding one among the plurality of memories comprised in the output unit in response to the first number of most significant bits and the second number of most significant bits.
The address generation section may include a first sub-address address generator and a second sub-address generator. The first sub-address generator may be configured to generate a plurality of first sub-addresses in a first matrix pattern in response to the first number of most significant bits and the second number of most significant bits. The second sub-address generator may be configured to generate a plurality of second sub-addresses in a second matrix pattern in response to the first number of most significant bits and the second number of most significant bits. Each of the selectors may transmit one address among the first sub-addresses and the second sub-addresses to the corresponding memory in response to the first number of most significant bits and the second number of most significant bits.
The first sub-address generator may perform adding and shifting on corresponding bits between the first number of most significant bits and the second number of most significant bits to generate the first sub-addresses for selecting a parameter which is selected by the first number of most significant bits and the second number of most significant bits, and parameters, which are in a relationship of the index pattern with respect to the selected parameter, in the look-up table including the plurality of indexes.
The first sub-address generator may include an adding and shifting part configured to perform adding and shifting on the corresponding bits between the first number of most significant bits and the second number of most significant bits to output added and shifted addresses, and an adding part configured to add addresses selected from among the added and shifted addresses to generate the first sub-addresses.
The semiconductor device may further include a ratio generator and a bilinear interpolator. The ratio generator may be configured to calculate a distance ratio between the correction parameters in response to a first number of least significant bits of the current pixel value and a second number of least significant bits of the previous pixel value. The bilinear interpolator may be configured to perform bilinear interpolation based on the correction parameters and the distance ratio output from the ratio generator to generate a correction value for the current pixel value.
Each of the current pixel value and the previous pixel value may indicate a pixel value for a color including red, green, or blue components.
According to an exemplary embodiment of the present invention, there is provided a display apparatus including a controller a display panel, and the above-described semiconductor device. The controller may control input and output of the current pixel value, the previous pixel value, and the correction parameters between the semiconductor device and the display panel.
According to an exemplary embodiment of the present invention, a method of generating correction parameters includes outputting a plurality of addresses in response to a first number of most significant bits of a current pixel value including a first selection bit and a second number of most significant bits of a previous pixel value including a second selection bit, determining correction parameters, which respectively correspond to the plurality of addresses, in response to the plurality of addresses, selecting one index pattern from a plurality of index patterns in response to the first selection bit and the second selection bit, arranging the determined correction parameters into the selected index pattern to generate arranged correction parameters, and outputting the arranged correction parameters. The index pattern may be a pattern that can be generated according to positions of the determined correction parameters in a look-up table including the plurality of indexes.
The outputting the arranged correction parameters may include outputting the correction parameters, which respectively correspond to the plurality of addresses, in response to the plurality of addresses using a memory unit including a plurality of memories, each of which stores a plurality of correction parameters according to one index among the plurality of indexes, and arranging the correction parameters output from the memory unit into the index pattern in response to the first selection bit and the second selection bit.
The outputting of the plurality of addresses may include generating a plurality of first addresses based on the first number of most significant bits and the second number of most significant bits, and transmitting one address among the plurality of first addresses to a corresponding each of the plurality of memories in response to the first number of most significant bits and the second number of most significant bits.
The generating of the plurality of first addresses may include generating a plurality of first sub-addresses in a first matrix pattern in response to the first number of most significant bits and the second number of most significant bits, and generating a plurality of second sub-addresses in a second matrix pattern in response to the first number of most significant bits and the second number of most significant bits. The transmitting of one address among the plurality of first addresses may include transmitting one address among the first sub-addresses and the second sub-addresses to each corresponding memory in response to the first number of most significant bits and the second number of most significant bits.
The generating of the plurality of first sub-addresses may include performing adding and shifting on corresponding bits between the first number of most significant bits and the second number of most significant bits to generate the first sub-addresses for selecting a parameter, which is selected by the first number of most significant bits and the second number of most significant bits, and parameters, which are in a relationship of the index pattern with respect to the selected parameter, in the look-up table including the plurality of indexes.
The generating of the plurality of first sub-addresses may include performing adding and shifting on corresponding bits between the first number of most significant bits and the second number of most significant bits to output added and shifted addresses, and adding addresses selected from among the added and shifted addresses to generate the first sub-addresses.
Each of the current pixel value and the previous pixel value may be indicate a pixel value for a color including red, green, or blue components.
The above and other features of the present invention will become more apparent by describing in detail exemplary embodiments thereof with reference to the attached drawings in which:
The present invention now will be described more fully hereinafter with reference to the accompanying drawings, in which embodiments of the invention are shown. This invention may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein. In the drawings, like numbers may refer to like elements throughout the specification.
It will be understood that when an element is referred to as being “connected” or “coupled” to another element, it can be directly connected or coupled to the other element or intervening elements may be present.
The controller 15 controls the input and output of a current pixel value CP, a previous pixel value PP, and correction parameters PRM0′, PRM1′, PRM2′, and PRM3′, generated by the correction parameter generator 30, among the pixel value storage unit 20, the correction parameter generator 30, the ratio generator 40, the bilinear interpolator 50, and the display panel 60.
The pixel value storage unit 20 stores the current pixel value CP and the previous pixel value PP and transmits the previous pixel value PP to the correction parameter generator 30 and the ratio generator 40 in response to a control signal CS1. The current pixel value CP and the previous pixel value PP may indicate a pixel value for a color including red (R), green (G), and blue (B) components. A point in time when the current pixel value CP is input is referred to as a reference point. The previous pixel value PP is a pixel value that is input immediately before the reference point. Accordingly, the current pixel value CP may be output as the previous pixel value PP, for example, when a next frame is input.
The pixel value storage unit 20 includes a memory controller 21 and a memory 23. The memory controller 21 generates a selection signal CS3 for selecting the previous pixel value PP, which is stored in the memory 23, in response to the control signal CS1. The memory controller 21 may receive the current pixel value CP and output it to the memory 23. The memory 23 stores the current pixel value CP and the previous pixel value PP and transmits the previous pixel value PP to the correction parameter generator 30 and the ratio generator 40 via the memory controller 21 in response to the selection signal CS3 output from the memory controller 21. The memory 23 may be embodied by a non-volatile memory such as for example, random access memory (RAM) or static RAM (SRAM).
The correction parameter generator 30 outputs the correction parameters PRM0′ through PRM3′ in response to a first “n” (where “n” is a natural number, e.g., 4) most significant bits CMSB of the current pixel value CP including a first selection bit and a second “n” most significant bits PMSB of the previous pixel value PP including a second selection bit.
The ratio generator 40 calculates a distance ratio between the correction parameters PRM0′ through PRM3′ output from the correction parameter generator 30 in response to a first “m” (where “m” is a natural number, e.g. 4) least significant bits CLSB of the current pixel value CP and a second “m” least significant bits PLSB of the previous pixel value PP. For example, when a difference between the correction parameters PRM0′ through PRM3′ is 16, the first “m” (e.g., m=4) least significant bits CLSB of the current pixel value CP and the second “m” least significant bits PLSB of the previous pixel value PP changes only in a range from “0001” to “1111”. Therefore, the distance ratio between the correction parameters PRM0′ through PRM3′ can be calculated based on the first “m” least significant bits CLSB of the current pixel value GP and the second “m” least significant bits PLSB of the previous pixel value PP.
The bilinear interpolator 50 receives the correction parameters PRM0′ through PRM3′ output from the correction parameter generator 30 and the distance ratio output from the ratio generator 40, and performs bilinear interpolation based on the received signals to generate a correction value OUTPUT for the current pixel value CP.
The display panel 60 receives the correction value OUTPUT for the current pixel value CP from the bilinear interpolator 50, performs correction of the current pixel value CP, and displays an image based on a corrected pixel value.
The address generator 31 outputs a plurality of addresses ADD0, ADD1 ADD2, and ADDS in response to the first “n” most significant bits CMSB of the current pixel value CP including a first selection bit cur[4] and the second “n” most significant bits PMSB of the previous pixel value PP including a second selection bit pre[4]. The address generator 31 includes an address generation section and a plurality of selectors M1, M3, M5, and M7. The address generation section includes a first sub-address generator 311 and a second sub-address generator 313 and generates first sub-addresses A0, A1, A2, and A3 and second sub-addresses A4 and A5 based on the first “n” most significant bits CMSB of the current pixel value CP and the second “n” most significant bits PMSB of the previous pixel value PP.
The first sub-address generator 311 generates the first sub-addresses A0 through A3 in a first matrix pattern in response to the first “n” most significant bits CMSB of the current pixel value GP and the second “n” most significant bits PMSB of the previous pixel value PP. The first matrix pattern is a predetermined address format (e.g., an 8*8 byte address, i.e., an address within an area AP1 in
The first sub-address generator 311 may perform adding and shifting on corresponding bits between the first “n” most significant bits CMSB of the current pixel value GP and the second “n” most significant bits PMSB of the previous pixel value PP to generate the first sub-addresses A0 through A3. Consequently, the first sub-address generator 311 generates the first sub-addresses A0 through A3 for selecting parameters (e.g., 213, 189, 232, and 212 illustrated in
The first sub-address generator 311 may include an adding-and-shifting part and an adding part. The adding-and-shifting part includes a first adder 311-1, a second adder 311-3, a first shifter 3115, and a second shifter 311-7 and performs adding and shifting on corresponding bits between the first “n” most significant bits CMSB of the current pixel value CP and the second “n” most significant bits PMSB of the previous pixel value PP to output added and shifted addresses AS0, AS1, AS2, and AS3.
The first adder 311-1 add “1” to the first “n” most significant bits CMSB of the current pixel value CP while the second adder 311-3 adds “1” to the second “n”; most significant bits PMSB of the previous pixel value PP. The first shifter 311-5 shifts an upper “r” (where “r” is a natural number, e.g., 3) bits Cur[7:5] in the first “n” most significant bits CMSB of the current pixel value CP to the left by “s” (where “s” is a natural number, e.g., 3). The first shifter 311-5 may include a selector (not shown) to select the upper “r” bits Cur[7:5] from the first “n” most significant bits CMSB of the current pixel value CP. The second shifter 311-7 selects “p” (where “p” is a natural number, e.g., 4) bits C[4:1] from the first “n” most significant bits CMSB of the current pixel value CP, to which “1” has been added by the first adder 311-1, and shifts the selected “p” bits C[4:1] to the left by “s”. The second shifter 311-7 may include a selector (not shown) to select the “p” bits C[4:1] from the first “n” most significant bits CMSB of the bit-added current pixel value CP.
Accordingly, when LUTs (e.g., LUTs illustrated in
The adding part includes a third adder 311-9, a fourth adder 311-11, a fifth adder 311-13, and a sixth adder 311-15, each of which adds addresses selected from among the added and shifted addresses AS0, AS1, AS2, and AS3 to generate the first sub-addresses A0 through A3.
The third adder 311-9 adds the first add and shifted address AS0 output from the first shifter 311-5 and the third added and shifted address AS2 to generate the first sub-address A0. The third added and shifted address AS2 may be an upper “r” bits Pre[7:5] selected from the second “n” most significant bits PMSB of the previous pixel value PP.
The fourth adder 311-11 adds the first added and shifted address AS0 output from the first shifter 311-5 and the fourth added and shifted address AS3 output from the second adder 311-3 to generate the first sub-address A1. The fourth added and shifted address AS0 may be “p” bits P[4:1] selected from the second “n” most significant bits PMSB of the previous pixel value PP, to which “1” has been added.
The fifth adder 311-13 adds the second added and shifted address AS1 output from the second shifter 311-7 and the third added and shifted address AS2 to generate the first sub-address A2. The third added and shifted address AS2 may be an upper “r” bits Pre[7:5] selected from the second “n” most significant bits PMSB of the previous pixel value PP.
The sixth adder 311-15 adds the second added and shifted address AS1 output from the second shifter 311-7 and the fourth added and shifted address AS3 output from the second adder 311-3 to generate the first sub-address A3. The fourth added and shifted address AS3 may be “p” bits P[4:1] selected from the second “n” most significant bits PMSB of the previous pixel value PP, to which “1” has been added.
The third and fifth adders 311-9 and 311-13 may include a predetermined selector (not shown) to select the upper “r” bits Pre[7:5] from the second “n” most significant bits PMSB of the previous pixel value PP during addition. Further, the fourth and sixth adders 311-11 and 311-15 may include a predetermined selector (not shown) to select the “p” bits P[4:1] from the second “n” most significant bits PMSB of the previous pixel value PP, to which “1” has been added.
The second sub-address generator 313 generates the second sub-addresses A4 and A5 having a second matrix pattern in response to the first “In” most significant bits CMSB of the current pixel value CP and the second “n” most significant bits PMSB of the previous pixel value PP. The second matrix pattern is a pattern having a parameter address located in an area (e.g., an area AP2 illustrated in
The second sub-address generator 313 includes a seventh adder 313-1 and an eighth adder 313-2. The seventh adder 313-1 adds a decimal “72” to the first “n” most significant bits CMSB of the current pixel value CP to generate the second sub-address A4. The seventh adder 313-1 may select an upper “r” bits Cur[7:5] from the first “n” most significant bits CMSB of the current pixel value CP and add the decimal “72” to the selected upper “r” bits Cur[7:5] to generate the second sub-address A4. The seventh adder 313-1 may include a separate selector (not shown).
The eighth adder 313-2 adds a decimal “64” to the second “n” most significant bits PMSB of the previous pixel value PP to generate the second sub-address A5. The eighth adder 313-2 may select an upper “r” bits Pre[7:5] from the second “n” most significant bits PMSB of the previous pixel value PP and add the decimal “64” to the selected upper “r” bits Pre[7:5] to generate the second sub-address A5. The eighth adder 313-2 may include a separate selector (not shown).
The decimal numbers “72” and “64” are calculated to set the addresses of parameters PRM0, PRM1, PRM2, and PRM3, which are positioned in an area (e.g. an area AP2 or AP3 illustrated in
Each of the selectors M1, M3, M5, and M7 transmits one address among the first sub-addresses A0 through A3, the second sub-addresses A4 and A5, and a third address 80 to a corresponding one among the first through fourth memories 33-1 through 33-7 in response to corresponding bits among a plurality of bits &cur[7:4] cur[4], pre[4] and &pre[7:4].
The first selector M1 transmits one address among the first sub-addresses A0 through A3 the second sub-addresses A4 and A5, and the third address 80 to the first memory 33-1 in response to third selection bits &cur[7:4], cur[4], pre[4], and &pre[7:4]. The second selector M3 transmits one address among the first sub-addresses A0 through AS3 and the second sub-address A4 to the second memory 33-3 in response to fourth selection bits cur[4], pre[4], and &pre[7:4]. The third selector M5 transmits one address among the first sub-addresses A0 through A3 and the second sub-address A5 to the third memory 335 in response to fifth selection bits &cur[7:4], cur[4], and pre[4]. The fourth selector M7 transmits one address among the first sub-addresses A0 through A3 to the fourth memory 33-7 in response to sixth selection bits cur[4] and pre[4].
The output unit includes the memory unit 33 and a parameter arranging unit 35. The output unit determines correction parameters PRM0. PRM1, PRM2, and PRM3, which respectively correspond to the plurality of the addresses ADD0, ADD1, ADD2, and ADD3, in response to the plurality of the addresses ADD0, ADD1, ADD2, and ADD3, selects one index pattern from a plurality of index patterns (e.g., index patterns illustrated in
According to an exemplary embodiment of the present invention, when the arranged correction parameters PRM0′ through PRM3′ are selected from a LUT, they are not directly selected from the LUT illustrated in
The memory unit 33 outputs the correction parameters PRM0 through PRM3, which respectively correspond to the addresses ADD0, ADD1, ADD2, and ADD3, in response to the addresses ADD0, ADD1, ADD2, and ADD3. The memory unit 33 may include the first through fourth memories 33-1 through 33-7 each of which includes an LUT that stores a plurality of correction parameters PRM0 through PRM3 according to an index among a plurality of indexes (e.g., 0, 1, 2, and 3).
The first memory 33-1 includes a first LUT (
The parameter arranging unit 35 receives the correction parameters PRM0 through PRM3 and arranges the correction parameters PRM0 through PRM3 into an index pattern in response to the first selection bit cur[4] and the second selection bit pre[4] to output the arranged correction parameters PRM0′ through PRM3′.
The first selection bit cur[4] may be a q-th bit (where “q” is a natural number, e.g., 4) in the first “n” most significant bits CMSB of the current pixel value CP and the second selection bit pre[4] may be a q-th bit in the second “n” most significant bits PMSB of the previous pixel value PP. For example, when the combination (cur[4],pre[4]) of the first selection bit cur[4] and the second selection bit pre[4] is (00), the index pattern may be the index pattern (a) illustrated in
The method of
The bit depth of CMSB (i.e., 1010) and PMSB (i.e.; 0101) can be variable and LUT size, for example, such as the LUT illustrated in
The second sub-address generator 313 generates the second sub-addresses A4=72 and A5=66 in the second matrix pattern in response to the first “n” most significant bits CMSB “1010” of the current pixel value CP “168” and the second “n” most significant bits PMSB “1010” of the previous pixel value PP “90”. The seventh adder 313-1 selects the upper “r” bits Cur[7:5] “101” from the first “n” most significant bits CMSB “1010” of the current pixel value CP “168” and adds the upper “r” bits Cur[7:5] “101” and a decimal number “72” to output a decimal number “77”. The second adder 313-2 selects the upper C′ bits Pre[7:5] “010” from the second “n” most significant bits PMSB “0101” of the previous pixel value PP “90” and adds the upper “r” bits Pre[7:5] “010” and a decimal number 64 to output a decimal number “66”.
The first selector M1 selects A1=43 as an address based on the third selection bits &cur[7:4]=1010, cur[4]=0, pre[4]=11 and &pre[7:4]=0101 and the table illustrated in
For clarity of description, real correction parameter values are not recorded in the first through fourth LUTs, but a real correction parameter value can be obtained by applying a coordinate value to the LUT illustrated in
In an operation S20, the memory unit 33 outputs the correction parameters PRM0 through PRM3, which respectively correspond to the addresses ADD0 through ADD3, to the parameter arranging unit 35 in response to the addresses ADD0 through ADD3.
The first memory 33-1 outputs a decimal “213” which refers to the first LUT illustrated in
In an operation S30, the parameter arranging unit 35 receives the correction parameters PRM0=213, PRM1=189, PRM2=232, and PRM3=212, and arranges them into an index pattern in response to the first selection bit cur[4] “0” and the second selection bit pre[4] “1” to output the arranged correction parameters PRM0′ through PRM3′. Since the combination of the first selection bit cur[4] “0” and the second selection bit pre[4] “1” is (0,1); the index pattern (b) illustrated in
At least one embodiment of the present invention may be stored as computer readable codes on a computer readable recording medium. The computer readable recording medium is any data storage device that can store data which can be thereafter read by a computer system. Examples of the computer readable recording medium include read-only memory (ROM), RAM, CD-ROMs, magnetic tapes, floppy disks, and optical data storage devices.
According to at least one embodiment of the present invention, correction parameters for a current pixel can be simultaneously extracted without wasting clock cycles by using memories respectively storing LUTs which are classified by indexes. In addition, according to at least one exemplary embodiment of the present invention, since the correction parameters for the current pixel can be extracted using the memories classified by indexes, the capacity of memory can be reduced.
While the present invention has been shown and described with reference to exemplary embodiments thereof it will be understood by those of ordinary skill in the art that various changes in form and detail may be made herein without departing from the spirit and scope of the present invention, as defined by the following claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2007-0003262 | Jan 2007 | KR | national |
Number | Name | Date | Kind |
---|---|---|---|
5696941 | Jung | Dec 1997 | A |
20060152463 | Furihata et al. | Jul 2006 | A1 |
Number | Date | Country |
---|---|---|
07-262081 | Oct 1995 | JP |
2004-304390 | Oct 2004 | JP |
2006-195170 | Jul 2006 | JP |
100135846 | Jan 1998 | KR |
Number | Date | Country | |
---|---|---|---|
20080170051 A1 | Jul 2008 | US |