The disclosure relates generally to display technology, and more particularly, to method and apparatus for subpixel rendering.
Displays are commonly characterized by display resolution, which is the number of distinct pixels in each dimension that can be displayed (e.g., 1920×1080). Many displays are, for various reasons, not capable of displaying different color channels at the same site. Therefore, the pixel grid is divided into single-color parts that contribute to the displayed color when viewed at a distance. In some displays, such as liquid crystal display (LCD), organic light emitting diode (OLED) display, electrophoretic ink (E-ink) display, or electroluminescent display (ELD), these single-color parts are separately addressable elements, which are known as subpixels.
Various subpixel arrangements (layouts, schemes) have been proposed to operate with a proprietary set of subpixel rendering algorithms in order to improve the display quality by increasing the apparent resolution of a display and by anti-aliasing text with greater details. For example, LCDs typically divide each pixel into three strip subpixels (e.g., red, green, and blue subpixels) or four quadrate subpixels (e.g., red, green, blue, and white subpixels). For OLED displays, due to the limitation of fabrication process, subpixels cannot be arranged too close to each other.
Color rendering approach has been applied to reduce the number of subpixels in each pixel without lowering the display resolution. PenTile® technology is one of the examples that implement the color rendering approach. In designing subpixel arrangements for displays, it is desired that different colors of subpixels, e.g., red, green, and blue subpixels, are uniformly distributed, i.e., the numbers of each color of subpixels are the same, and the distances between different colors of subpixels are substantially the same. However, for subpixel arrangements using PenTile® technology, the number of green subpixels is twice of the number of red or blue subpixel, i.e., the resolution of red or blue color is half of the resolution of green color. The distance between two adjacent subpixels with different colors (relative distance) also varies for subpixel arrangements using PenTile® technology.
It is also commonly known that each pixel on a display can be associated with various attributes, such as luminance (brightness, a.k.a. luma,) and chrominance (color, a.k.a. chroma) in the YUV color model. Most of the known solutions for subpixel rendering use native display data generated based on the RGB color model, which consists of three primary color components, red (R), green (G), and blue (B). However, since the human vision system is not as sensitive to color as to brightness, the known solutions of using three or four subpixels to constitute a full-color pixel and rendering the subpixels using native RGB display data may cause the waste of display bandwidth and thus, are not always desirable.
Accordingly, there exists a need for improved method and apparatus for subpixel rendering to overcome the above-mentioned problems.
The disclosure relates generally to display technology, and more particularly, to method and apparatus for subpixel rendering.
In one example, a method for subpixel rendering is provided. For each of an array of pixels on a display, a first signal including a first set of components is received. The first set of components of the first signal are then converted to a second set of components of the first signal. The second set of components of the first signal include a first component representing a first attribute of the pixel and a second component representing a second attribute of the pixel. The second set of components of the first signal are then modified to generate a second signal including a modified second set of components by applying at least one operation to at least one of the first and second components based on the corresponding attribute of the pixel. The modified second set of components of the second signal are then converted to a modified first set of components of the second signal. A third signal is generated based on the modified first set of components of the second signal for rendering subpixels corresponding to the pixel.
In a different example, a device for subpixel rendering includes a first signal converting unit, a signal processing module, a second signal converting unit, and a subpixel rendering module. The first signal converting unit is configured to, for each of an array of pixels on a display, receive a first signal including a first set of components. The first signal converting unit is further configured to convert the first set of components of the first signal to a second set of components of the first signal. The second set of components of the first signal include a first component representing a first attribute of the pixel and a second component representing a second attribute of the pixel. The signal processing module is configured to, for each pixel, modify the second set of components of the first signal to generate a second signal including a modified second set of components by applying at least one operation to at least one of the first and second components based on the corresponding attribute of the pixel. The second signal converting unit is configured to, for each pixel, convert the modified second set of components of the second signal to a modified first set of components of the second signal. The subpixel rendering module is configured to generate a third signal based on the modified first set of components of the second signal for rendering subpixels corresponding to the pixel.
In another different example, an apparatus includes a display and control logic. The display has an array of subpixels arranged in a repeating pattern thereon. Two adjacent subpixels in the same row of subpixels correspond to a pixel on the display. A first subpixel repeating group and a second subpixel repeating group are alternatively applied to two adjacent rows of subpixels. Two adjacent rows of subpixels are staggered with each other. The control logic is operatively connected to the display and configured to render the array of subpixels. The control logic includes a first signal converting unit, a signal processing module, a second signal converting unit, and a subpixel rendering module. The first signal converting unit is configured to, for each of an array of pixels on a display, receive a first signal including a first set of components. The first signal converting unit is further configured to convert the first set of components of the first signal to a second set of components of the first signal. The second set of components of the first signal include a first component representing a first attribute of the pixel and a second component representing a second attribute of the pixel. The signal processing module is configured to, for each pixel, modify the second set of components of the first signal to generate a second signal including a modified second set of components by applying at least one operation to at least one of the first and second components based on the corresponding attribute of the pixel. The second signal converting unit is configured to, for each pixel, convert the modified second set of components of the second signal to a modified first set of components of the second signal. The subpixel rendering module is configured to generate a third signal based on the modified first set of components of the second signal for rendering the two subpixels corresponding to the pixel.
Other concepts relate to software for implementing the method for subpixel rendering. A software product, in accord with this concept, includes at least one machine-readable non-transitory medium and information carried by the medium. The information carried by the medium may be executable program code data regarding parameters in association with a request or operational parameters, such as information related to a user, a request, or a social group, etc.
In one example, a machine readable and non-transitory medium having information recorded thereon for subpixel rendering, where when the information is read by the machine, causes the machine to perform a series of steps. For each of an array of pixels on a display, a first signal including a first set of components is received. The first set of components of the first signal are then converted to a second set of components of the first signal. The second set of components of the first signal include a first component representing a first attribute of the pixel and a second component representing a second attribute of the pixel. The second set of components of the first signal are then modified to generate a second signal including a modified second set of components by applying at least one operation to at least one of the first and second components based on the corresponding attribute of the pixel. The modified second set of components of the second signal are then converted to a modified first set of components of the second signal. A third signal is generated based on the modified first set of components of the second signal for rendering subpixels corresponding to the pixel.
The embodiments will be more readily understood in view of the following description when accompanied by the below figures and wherein like reference numerals represent like elements, wherein:
In the following detailed description, numerous specific details are set forth by way of examples in order to provide a thorough understanding of the relevant disclosures. However, it should be apparent to those skilled in the art that the present disclosure may be practiced without such details. In other instances, well known methods, procedures, systems, components, and/or circuitry have been described at a relatively high-level, without detail, in order to avoid unnecessarily obscuring aspects of the present disclosure.
Among other novel features, the present disclosure provides the ability to reduce display bandwidth while maintaining the same or similar apparent display resolution. It is understood that different components in the display data are not equally important for apparent display resolution as the human vision system has different levels of sensitivities with respect to different attributes represented by each component in the display data. For example, compared to luminance component, chrominance component is less important for apparent display resolution, and the changes of chrominance component among adjacent pixels are more gradual (lower bandwidth). As a result, components that are less important for apparent display resolution, such as chrominance component, can be reduced in the display data to save display bandwidth. Such ability promotes subpixel rendering on a display. The novel subpixel rendering method and subpixel arrangements in the present disclosure do not compromise the apparent color resolution and uniformity of color distribution on the display. In one example of the present disclosure, as each pixel is divided equally into two subpixels instead of the conventional three strip subpixels or four quadrate subpixels, the number of addressable display elements per unit area of a display can be increased without changing the current manufacturing process.
Additional novel features will be set forth in part in the description which follows, and in part will become apparent to those skilled in the art upon examination of the following and the accompanying drawings or may be learned by production or operation of the examples. The advantages of the present teachings may be realized and attained by practice or use of various aspects of the methodologies, instrumentalities, and combinations set forth in the detailed examples discussed below.
In one example, the apparatus 100 may be a laptop or desktop computer having a display 102. In this example, the apparatus 100 also includes a processor 114 and memory 116. The processor 114 may be, for example, a graphic processor (e.g., GPU), a general processor (e.g., APU, accelerated processing unit; GPGPU, general-purpose computing on GPU), or any other suitable processor. The memory 116 may be, for example, a discrete frame buffer or a unified memory. The processor 114 is configured to generate display data 106 in display frames and temporally store the display data 106 in the memory 116 before sending it to the control logic 104. The processor 114 may also generate other data, such as but not limited to, control instructions 118 or test signals, and provide them to the control logic 104 directly or through the memory 116. The control logic 104 then receives the display data 106 from the memory 116 or from the processor 114 directly. In other examples, at least part of the control logic 104 may be implemented as software that is stored in the memory 116 and executed by the processor 114.
In another example, the apparatus 100 may be a television set having a display 102. In this example, the apparatus 100 also includes a receiver 120, such as but not limited to, an antenna, radio frequency receiver, digital signal tuner, digital display connectors, e.g., HDMI, DVI, DisplayPort, USB, Bluetooth, WiFi receiver, or Ethernet port. The receiver 120 is configured to receive the display data 106 as an input of the apparatus 100 and provide the display data 106 to the control logic 104.
In still another example, the apparatus 100 may be a handheld device, such as a smart phone or a tablet. In this example, the apparatus 100 includes the processor 114, memory 116, and the receiver 120. The apparatus 100 may both generate display data 106 by its processor 114 and receive display data 106 through its receiver 120. For example, the apparatus 100 may be a handheld device that works as both a portable television and a portable computing device. In any event, the apparatus 100 at least includes the display 102 and control logic 104 for rendering the array of subpixels on the display 102.
Referring now to
The display panel 210 may be, for example, a TN panel, an IPS panel, an AFFS panel, a VA panel, an ASV panel, or any other suitable display panel. In this example, the display panel 210 includes a filter substrate 220, an electrode substrate 224, and a liquid crystal layer 226 disposed between the filter substrate 220 and the electrode substrate 224. As shown in
As shown in
In this example, the display panel 310 includes a light emitting substrate 318 and an electrode substrate 320. As shown in
As shown in
Although
The signal converting module 402 may include one or more units for converting display signals between different types. It is known that the display data 106 may be represented using various color models, including but not limited to RGB (red, green, blue) color model, YUV (luminance, chrominance) color mode, HSL (hue, saturation, luminance) color model, HSB (hue, saturation, brightness) color model, etc. The display data 106 includes a set of components based on the particular color model. For example, display data represented using RGB model includes R, G, and B, three primary color components; display data represented using YUV color models includes one luminance component Y and two chrominance components U and V; display data represented using HSL color model includes one hue component H, one saturation component S, and one luminance component L. The various types of display signals can be converted between each other by the signal converting module 402 using any known color model conversion algorithms as known in the art.
The signal converting module 402 may include a first signal converting unit configured to, for each pixel on the display 102, receive a first signal including a first set of components and convert the first set of components to a second set of components of the first signal. The first signal may be initially generated using RGB color model such that each of the first set of components represents the same attribute of a pixel, i.e., colors, has the same display bandwidth, and is equally important for apparent display resolution. The second set of components of the first signal on the other hand, include a first component representing a first attribute of the pixel and a second component representing a second attribute of the pixel. The first and second components represent different attributes of a pixel, such as luminance and chrominance components, each of which has a different display bandwidth and is not equally important for apparent display resolution.
The signal converting module 402 may also include a second signal converting unit configured to, for each pixel on the display 102, convert the second set of components, either in its native form or in a modified form by signal processing, back to the corresponding first set of components. That is, the first and second signal converting units perform inverse conversions between two types of display signals.
In this example, the signal converting module 402 includes an RGB-YUV converting unit 408 and a YUV-RGB converting unit 410. The RGB-YUV converting unit 408 is configured to receive the native display data 106 including R, G, and B components, convert the R, G, and B components to Y, U, and V components. R, G, and B components are considered as representing the same attribute of a pixel, i.e., colors, while Y, U, and V components represent two different attributes of a pixel, i.e., luminance and chrominance. The YUV-RGB converting unit 410 is configured to convert the Y, U, and V components back to the R, G, and B components.
The signal processing module 404 may include one or more signal processing units, each of which is capable of applying one signal processing operation to at least one component of a display signal based on the corresponding attribute of a pixel represented by the component. The signal processing module 404 in this example is configured to, for each pixel on the display 102, modify the second set of components of the first signal to generate a second signal including a modified second set of components and convert the modified second set of components of the second signal to a modified first set of components of the second signal. The signal processing units may include, for example, a Fourier transform/inverse Fourier transform unit 412 and a low-pass filtering unit 414 as shown in
In this example, for each pixel, the converted Y, U, and V components are sent from the RGB-YUV converting unit 408 to the Fourier transform/inverse Fourier transform unit 412. Fourier transform is applied to each or some of the Y, U, and V components, followed by low-pass filtering performed by the low-pass filtering unit 414 in the frequency domain. The filtered Y, U, and V components are sent back to the Fourier transform/inverse Fourier transform unit 412 where the inverse Fourier transform is applied to generate modified Y, U, and V components. The modified Y, U, and V components are converted to modified R, G, and B components by the YUV-RGB converting unit 410 as mentioned above. It is noted that as the Y, U, and V components represent different attributes of a pixel with different display bandwidths, the manner in which the signal processing operation(s) are applied to each of the Y, U, and V components are also different. It is known that Y component is more important for apparent display resolution (higher bandwidth) than the U and V components. In one example, signal processing operation(s) are applied only to the U and V components by the signal processing module 404 to reduce their bandwidths while the Y component is intact. In another example, signal processing operation(s) are applied to each of the Y, U, and V components by the signal processing module 404 but at different degrees. For example, a higher cutoff frequency may be applied by the low-pass filtering unit 414 to the Y component compared with the U and V components so that more information in the Y component can be persevered.
The subpixel rendering module 406 is configured to generate a third signal based on the modified first set of components of the second signal. In this example, the subpixel rendering module 406 generates the control signals 108 for rendering each subpixel on the display 102 based on the second signal. As mentioned above, the display signals may be represented at the pixel level and thus, need to be converted to the control signals 108 for driving each of the subpixels by the subpixel rendering module 406. In the example shown in
Proceeding to block 506, for each pixel, the second set of components of the first signal are modified to generate a second signal including a modified second set of components by applying at least one operation to at least one of the first and second components based on the corresponding attribute of the pixel. The at least one operation reduces bandwidth of the at least one of the first and second components and includes, for example, Fourier transform and filtering. In one example, the at least one operation is applied to only one of the first and second components determined based on the corresponding attribute of the pixel, e.g., U and V components corresponding to chrominance of the pixel. In another example, the at least one operation is applied to each of the first and second components in a manner determined based on the corresponding attribute of the pixel. For example, a cutoff frequency of low-pass filtering applied to the first and second components is determined based on the corresponding attribute of the pixel. As mentioned above, this may be implemented by the signal processing module 404 of the control logic 104.
Moving to block 508, for each pixel, the modified second set of components of the second signal are converted to a modified first set of components of the second signal. Each component of the modified first set of components of the second signal may represent the same attribute of the pixel. For example, the modified first set of components of the second signal include RGB components. As mentioned above, this may be implemented by the signal converting module 402 of the control logic 104.
At block 510, for each pixel, a third signal is generated based on the modified first set of components of the second signal for rendering subpixels corresponding to the pixel. Each pixel may be divided into two subpixels rendered by the third signal, and for each pixel, at block 512, the two subpixels are rendered based on a corresponding component in the modified first set of components of the second signal. As mentioned above, blocks 510 and 512 may be implemented by the subpixel rendering module 406 of the control logic 104.
As mentioned above, this may be implemented by the RGB-YUV converting unit 408 of the control logic 104.
Referring back to
u(ω)=Fu(n) (2)
It is noted that in this example, as U components of each pixel in a row are discrete signals, discrete Fourier transform (DFT) is applied. Referring back to
u′(n)=F−1u′(ω) (3)
It is noted that in this example, as the modified U components of each pixel in a row are discrete signals, discrete inverse Fourier transform (DIFT) is applied. As mentioned above, blocks 604, 606, and 608 may be implemented by the Fourier transform/inverse Fourier transform unit 412 and low-pass filtering unit 414 of the control logic 104.
Referring back to
For Y components, Fourier transform, filtering, and inverse Fourier transforms may be also applied to each row of pixels at blocks 616, 618, and 620, respectively. As the human vision system is more sensitive to brightness than to color, the luminance component (Y) is considered to be more important than the chrominance components (U and V). In this example, a higher cutoff frequency is applied at block 618 for low-pass filtering of the Y component compared to the cutoff frequencies that are applied at blocks 606 and 612 for low-pass filtering of the U and V components. Thus, more information in the luminance component is preserved than that in the chrominance components. In another example, blocks 616, 618 and 620 may be omitted such that the Y components in the native display data remain intact.
Proceeding to block 622, for each pixel of the display 102, the modified Y, U, and V components in a second display signal are converted to modified R, G, and B components in the second display signal. Now referring to
As mentioned above, this may be implemented by the YUV-RGB converting unit 410 of the control logic 104. It is also understood that the processing blocks for each component may be implemented as a processing pipeline, and multiple processing pipelines for each component may be executed in parallel.
As shown in
As shown in
As a result of the subpixel arrangement described above with respect to
In this embodiment, the subpixels are rendered by the control signals 108, i.e., the third signals in
Aspects of the method for subpixel rendering, as outlined above, may be embodied in programming. Program aspects of the technology may be thought of as “products” or “articles of manufacture” typically in the form of executable code and/or associated data that is carried on or embodied in a type of machine readable medium. Tangible non-transitory “storage” type media include any or all of the memory or other storage for the computers, processors or the like, or associated modules thereof, such as various semiconductor memories, tape drives, disk drives and the like, which may provide storage at any time for the software programming.
All or portions of the software may at times be communicated through a network such as the Internet or various other telecommunication networks. Such communications, for example, may enable loading of the software from one computer or processor into another, for example, from a management server or host computer of the search engine operator or other explanation generation service provider into the hardware platform(s) of a computing environment or other system implementing a computing environment or similar functionalities in connection with generating explanations based on user inquiries. Thus, another type of media that may bear the software elements includes optical, electrical and electromagnetic waves, such as used across physical interfaces between local devices, through wired and optical landline networks and over various air-links. The physical elements that carry such waves, such as wired or wireless links, optical links or the like, also may be considered as media bearing the software. As used herein, unless restricted to tangible “storage” media, terms such as computer or machine “readable medium” refer to any medium that participates in providing instructions to a processor for execution.
Hence, a machine readable medium may take many forms, including but not limited to, a tangible storage medium, a carrier wave medium or physical transmission medium. Non-volatile storage media include, for example, optical or magnetic disks, such as any of the storage devices in any computer(s) or the like, which may be used to implement the system or any of its components as shown in the drawings. Volatile storage media include dynamic memory, such as a main memory of such a computer platform. Tangible transmission media include coaxial cables; copper wire and fiber optics, including the wires that form a bus within a computer system. Carrier-wave transmission media can take the form of electric or electromagnetic signals, or acoustic or light waves such as those generated during radio frequency (RF) and infrared (IR) data communications. Common forms of computer-readable media therefore include for example: a floppy disk, a flexible disk, hard disk, magnetic tape, any other magnetic medium, a CD-ROM, DVD or DVD-ROM, any other optical medium, punch cards paper tape, any other physical storage medium with patterns of holes, a RAM, a PROM and EPROM, a FLASH-EPROM, any other memory chip or cartridge, a carrier wave transporting data or instructions, cables or links transporting such a carrier wave, or any other medium from which a computer can read programming code and/or data. Many of these forms of computer readable media may be involved in carrying one or more sequences of one or more instructions to a processor for execution.
The above detailed description of the disclosure and the examples described therein have been presented for the purposes of illustration and description only and not by limitation. It is therefore contemplated that the present disclosure cover any and all modifications, variations or equivalents that fall within the spirit and scope of the basic underlying principles disclosed above and claimed herein.
This application is divisional U.S. application Ser. No. 14/817,613, filed on Aug. 4, 2015, entitled “METHOD AND APPARATUS FOR SUBPIXEL RENDERING,” which is continuation of International Application No. PCT/CN2013/083355, filed on Sep. 12, 2013, entitled “METHOD AND APPARATUS FOR SUBPIXEL RENDERING,” all of which are hereby incorporated by reference in their entireties.
Number | Name | Date | Kind |
---|---|---|---|
20020070909 | Asano et al. | Jun 2002 | A1 |
20030234795 | Lee | Dec 2003 | A1 |
20050083352 | Higgins | Apr 2005 | A1 |
20050185836 | Huang | Aug 2005 | A1 |
20060061538 | Dispoto | Mar 2006 | A1 |
20060076550 | Kwak et al. | Apr 2006 | A1 |
20070058113 | Wu et al. | Mar 2007 | A1 |
20070257944 | Miller | Nov 2007 | A1 |
20090046108 | Brown Elliott | Feb 2009 | A1 |
20120148209 | Gunji | Jun 2012 | A1 |
20130027437 | Gu | Jan 2013 | A1 |
20130077887 | Elton | Mar 2013 | A1 |
20150339969 | Gu | Nov 2015 | A1 |
Number | Date | Country |
---|---|---|
1662071 | Aug 2005 | CN |
101442683 | May 2009 | CN |
WO 2013130186 | Sep 2013 | WO |
WO 2015149476 | Oct 2015 | WO |
Entry |
---|
International Search Report dated Jun. 12, 2014 in International Application No. PCT/CN2013/083355. |
European Search Report directed to European Patent Application No. 13893424.5, dated Jan. 16, 2017. |
Number | Date | Country | |
---|---|---|---|
20170178555 A1 | Jun 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14817613 | Aug 2015 | US |
Child | 15451584 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/CN2013/083355 | Sep 2013 | US |
Child | 14817613 | US |