The present disclosure relates generally to color digital image processing, and more particularly to an improved system and method for display rotation.
It is well known that different color spaces such as a red, green, blue (RGB) primary color model, may be used to represent, process and/or describe color. Similar to the RGB primary color model, YUV is a well known and widely used color model for describing color space (or color information) in terms of luminance (Y) component that is indicative of the brightness and chrominance (U and V) components that are indicative of the color. The human eye is less sensitive to color variations than to intensity variations. The YUV format allows the encoding of luminance (Y) information at full bandwidth/resolution and chrominance (UV) information at reduced bandwidth/resolution. The YUV format, which was originally developed for backward compatibility with black and white television, uses a matrixed combination of RGB to reduce the amount of information in the signal for conserving bandwidth.
Chroma sub-sampling, which is a well known sampling technique, generally refers to the use of lower resolution (fewer bits) for digitally sampling the chrominance (U and V) information in an image compared to the luminance (Y) information. The chroma sub-sampling is usually expressed as a three part ratio of the number of luminance (Y) samples, followed by the number of samples of the chrominance (U and V) components for each sampled area of the image. For example, a YUV 4:2:2 samples the two color-difference components (U and V) at half the sample rate of the brightness (Y) component, thereby utilizing less memory and less bandwidth compared to a YUV 4:4:4 sample.
Pixel data associated with a digital image may be typically stored in memory. The digital image may be retrieved from the memory and displayed as a two dimensional display on an image output device, such as a display device, a printer device and similar others. The display device may include a liquid crystal display (LCD), a plasma display, a television (TV), a projector display and similar others. A user viewing the display may desire to rotate the display for optimized viewing, e.g., change from a portrait display orientation to a landscape display orientation. Traditional techniques for rotating the display may include use of software, which may be slow in terms of desired performance. Some techniques may use additional main memory as a temporary memory area for copying the image data into the temporary memory and then manipulating the copied image data for rotation. However, such techniques may be less efficient and costly due to the need for performing additional reads and writes on the image data to perform the rotation.
Applicants recognize an existing need for an improved method and system for rotating two dimensional color images stored in a memory as sub-sampled data, the improved method and system providing an improved performance, efficiency and cost. In addition, the applicants recognize the advantage of providing the flexibility to display the automatic rotation of color images on a variety of display devices such as liquid crystal displays (LCD) displays and television (TV) display screens, absent the disadvantages found in the prior techniques discussed above.
The foregoing need is addressed by the teachings of the present disclosure, which relates to an improved method and system for rotating two dimensional color images stored in a memory as sub-sampled data. According to one embodiment, in a method and system for controlling rotation of a color image stored as sub-sampled image data in a memory, a controller includes a finite state machine (FSM) operable to fetch the sub-sampled image data and provide the sub-sampled data as a plurality of pixels to form the color image having a predefined angle of rotation. The FSM provides a predefined address of sub-sampled image data describing the color image stored in the memory to an addressing unit. The addressing unit is operable to read twice the sub-sampled image data located at the predefined address. A memory device is operable to push each read instance of the sub-sampled image data. A pipeline controlled by the FSM is operable to pull and selectively read the sub-sampled image data from the memory device for generating the plurality of pixels.
In one aspect of the disclosure, a method for rotating a color image stored in a memory as sub-sampled data includes reading sub-sampled image data describing the color image. The sub-sampled image data is located at a predefined address of the memory. The sub-sampled image data is pushed in a memory device. The same sub-sampled image data is re-read and pushed in the memory device, thereby generating substantially identical records in the memory device. A plurality of pixels is generated by selectively reading the sub-sampled image data, including the substantially identical records. The plurality of pixels form the color image having a predefined angle of rotation.
Several advantages are achieved by the method and system for two dimensional rotation of color images stored as sub-sampled data according to the illustrative embodiments presented herein. The embodiments advantageously provide a controller to automatically control rotation of a color image stored as sub-sampled image data in a memory. The improved rotation technique advantageously provides reading of the sub-sampled data twice to generate pixels forming the rotated color image in real time, thereby providing improved performance, efficiency and cost. This advantageously enables manufacturers of display systems to improve user experience.
Novel features that may be considered characteristic of the present disclosure are set forth in the appended claims. The disclosure itself, however, as well as a preferred mode of use, various objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings. The functionality of various circuits, devices or components described herein may be implemented as hardware (including discrete components, integrated circuits and systems-on-a-chip ‘SoC’), firmware (including application specific integrated circuits and programmable chips) and/or software or a combination thereof, depending on the application requirements.
Many traditional display rotation techniques often deploy software, which may be slow in terms of desired performance. Some techniques may use additional main memory to copy and subsequently manipulate color image data for the rotation, thereby requiring additional read/write operation and additional memory cost. These problems may be addressed by an improved system and method for rotating two dimensional color images stored in a memory as sub-sampled data. In an improved method and system for rotating two dimensional color images stored in a memory as sub-sampled data, the memory data is selectively read twice for each column, pushed in a memory device, pulled from the memory device and selectively read to generate the rotated color image displayable on a LCD and/or a TV display.
According to one embodiment, in a method and system for controlling rotation of a color image stored as sub-sampled image data in a memory, a controller includes a finite state machine (FSM) operable to fetch the sub-sampled image data and provide the sub-sampled data as a plurality of pixels to form the color image having a predefined angle of rotation. The FSM provides a predefined address of sub-sampled image data describing the color image stored in the memory to an addressing unit. The addressing unit is operable to read twice the sub-sampled image data located at the predefined address. A memory device is operable to push each read instance of the sub-sampled image data. A pipeline controlled by the FSM is operable to pull and selectively read the sub-sampled image data from the memory device for generating the plurality of pixels.
The following terminology may be useful in understanding the present disclosure. It is to be understood that the terminology described herein is for the purpose of description and should not be regarded as limiting.
YUV—is a well known color model for describing color space (or color information) in terms of luminance (Y) component that is indicative of the brightness and chrominance (U and V) components that are indicative of the color.
Chrominance (U and V) sub-sampling—is a well known sampling technique and generally refers to the use of lower resolution (e.g., fewer bits) for digitally sampling the chrominance (U and V) information in a color image compared to the luminance (Y) information. The chrominance sub-sampling is usually expressed as a three part ratio of the number of luminance (Y) samples, followed by the number of samples of the chrominance (U and V) components for each sampled area of the image, e.g., for each pixel of the color image. For example, a YUV 4:2:2 samples the two color-difference components (U and V) at half the sample rate of the brightness (Y) component, thereby utilizing less memory and less bandwidth compared to a YUV 4:4:4 sample. The YUV color space may be typically encoded using 8 bits per pixel for Y and, effectively 4 bits per pixel for U and V (to reflect the 4:2:2 sampling), for a total of 16 bits (2 bytes) per pixel instead of 24 bits per pixel for the YUV 4:4:4 sampling. Thus, YUV 4:2:2 sub-sampled data for two adjacent pixels may be stored in 32 bits of memory. The luminance (Y) is often described as an independent component and the chrominance (U and V) is described as a shared component between the adjacent pixels. The color image may be reconstructed for display from the YUV 4:2:2 sub-sampled image data stored in the memory. It should be emphasized that, while processing sub-sampled data stored in memory, individual samples in the sub-sampled data may no longer apply only to single pixels, but includes information shared between several pixels.
Device—Any electronic machine or component that is operable to perform at least one predefined function. Examples of electronic devices may include power supplies, digital signal processors, flip flops, controllers, memory chips, displays, processors, and communication interfaces. Many devices may require a software program to interact between a user and the device and/or between devices.
System—One or more interdependent devices that co-operate to perform one or more predefined functions.
Configuration—Describes a set up of a device and/or a system and refers to a process for setting, defining, or selecting hardware and/or software properties, parameters, or attributes of the device and/or the system.
In a particular embodiment, the controller 120 is coupled to the memory 110 via a direct memory access (DMA) channel 118 to facilitate a high data transfer rate. The memory 110 stores color image data. In a particular embodiment, the memory 110 stores sub-sampled image data 116, e.g., YUV 4:2:2 sub-sampled data, describing the color image. For example, as described earlier, 32 bits of the memory 110 may be used to save two 16 bit YUV 4:2:2 samples describing two adjacent pixels of a plurality of pixels forming the color image 140.
In the depicted embodiment, the color image 140 is formed by 4×3 pixels shown as Y0U0V0 142, YU0V0 144, Y2U2V2 146, Y3U2V2 148, Y4U4V4 150, Y5U4V4 152, Y6U6V6 154, Y7U6V6 156, Y8U8V8 158, Y9U8V8 160, Y10U10V10162, and Y11U10V10 164. In this embodiment, the initial angle shown is 0 degrees, e.g., indicative of no rotation. A clockwise 90 degree rotated color image 170 is formed by rotating the 4×3 pixels of the color image 140 to form 3×4 pixels of the rotated color image 170. The rotated color image 170 is shown as Y8U8V8 158, Y4U4V4 150, Y0U0V0 142, Y9U8V8 160, Y5U4V4 152, Y1U0V0 144, Y10U10V10 162, Y6U6V6 154, Y2U2V2 146, Y11U10V10 164, Y7U6V6 156 and Y3U2V2 148.
Although a 90 degree angle of rotation is described, the predefined angle of rotation is selectable to be any one of 90 degrees and 270 degrees relative to an initial angle such as 0 degrees. A 3×4 pixel 270 degree rotated color image 174 is shown as Y3U2V2 148, Y7U6V6 156, Y11U10V10 164, Y2U2V2 146, Y6U6V6 154, Y10U10V10 162, Y1U0V0 144, Y5U4V4 152, Y9U8V8 160, Y0U0V0 142, Y4U4V4 150 and Y8U8V8 158.
In the depicted embodiment, the memory 110 stores the YUV 4:2:2 sub-sampled data 116 shown as Y0U0Y1V0 102, Y2U2Y3V2 104, Y4U4Y5V4 106, Y6U6Y7V6 108, Y8U8Y9V8 112, and Y10U10Y11V10 114 describing the color image 140. Thus, 32 bits of sub-sampled data Y0U0Y1V0 102 is used to generate the adjacently located 16-bit pixels Y0U0V0 142 and Y1UOV0 144 of the color image 140. The memory 110 is shown as a memory array having m rows and n columns, where m=3 and n=2. The rotated color image 170 is generated from the same YUV 4:2:2 sub-sampled data.
In an exemplary non-depicted embodiment, the display device 130 is a liquid color display (LCD) display. In this embodiment, the plurality of pixels are displayed on the LCD display in a non-interlaced manner. In an exemplary non-depicted embodiment, the display device 130 is a television (TV) display. In this embodiment, the plurality of pixels are displayed on the TV display in an interlaced manner.
In an exemplary non-depicted embodiment, the display system 100 may be included as a part of a computer system. It should be understood that the term “computer system” is intended to encompass any device having a processor that executes instructions from a memory medium.
The FSM 210 may be implemented as a digital circuit operable to execute combinatorial logic. The FSM 210 may include electronic devices such as field programmable gate arrays (FPGA's), a programmable logic device, logic gates and/or flip flops.
In the depicted embodiment, the FSM 210 controls the operation of a addressing unit 220 and a pipeline 230. In a particular embodiment, the FSM 210 controls the operation of the addressing unit 220 by providing a predefined starting address the number of rows of the memory 110 for a read operation. The predefined address may be defined as a function of the predefined angle of rotation. The FSM 210 may also provide the addressing unit 220 with an addressing mode, a pixel offset and a row offset. The addressing mode may be configured to be one of a linear addressing mode, a single offset addressing mode and a double offset addressing mode.
In a particular embodiment, the addressing unit 220 is operable to read the sub-sampled image data 116 such as Y0U0Y1V0 102, Y2U2Y3V2 104, Y4U4Y5V4 106, Y6U6Y7V6 108, Y8U8Y9V8 112, and Y10U10Y11V10 114 twice. That is, the addressing unit 220 is operable to read the predefined memory locations such as a column twice, as directed by the FSM 210. In a particular embodiment, the twice read data is pushed into a memory device 240 after each read operation. The memory device 240 is a first in first out (FIFO) device having a predefined depth. The size of the memory device 240 is substantially less than the size of the memory 110 to advantageously reduce cost. In a particular embodiment, the size of the memory device 240 is 1024 bytes compared to mega bytes for the memory 110. In the depicted embodiment, the twice read sub-sampled data Y8U8Y9V8 112, Y4U4Y5V4 106, Y0U0Y1V0 102 is stored/pushed twice in the memory device 240.
In the depicted embodiment, the pipeline 230 is controlled by the FSM 210 to pull the twice sub-sampled image data from the memory device 240 for generating the plurality of pixels Y8U8V8 158, Y4U4V4 150, Y0U0V0 142, Y9U8V8 160, Y5U4V4 152, Y1U0V0 144, Y10U10V10 162, Y6U6V6 154, Y2U2V2 146, Y11U10V10 164, Y7U6V6 156 and Y3U2V2 148 to form the rotated color image 170. Additional details of combinatorial logic executed by the FSM 210 to control the pipeline 230 are described with reference to
In a particular embodiment, the plurality of pixels are output by rows during each pass. In the depicted embodiment, the pipeline 230 includes a row counter 232 for the rows. In a particular embodiment, the row counter 232 may be set to an odd or even value depending on an odd or even row being output. Each pixel of the rotated color image 170 is generated by selectively reading an independent component (Y) and a shared component (U and V) stored in each row of the memory device 240 in response to the row counter. For example, a first independent component Y8 and a first shared component U8V8 are selectively read from the memory device 240 to generate the first pixel Y8U8Y9V8 112 of the first row (odd row). A second independent component Y9 and the first shared component U8V8 are selectively read from the memory device 240 to generate the fourth pixel Y9U8V8 160 of the second row (even row). In a particular embodiment, the plurality of pixels corresponding to each odd or even row identified by the row counter are provided in accordance with the interleaving and non-interleaving format for the TV display and the LCD display.
In a particular embodiment, the addressing unit 220 operates asynchronously with the pipeline 230. That is, reading of the sub-sampled data from the memory 110 may occur asynchronously with the pipeline 230 generating the plurality of pixels. In another embodiment, the operation of the addressing unit 220 and the pipeline 230 may be synchronous.
Various steps described above may be added, omitted, combined, altered, or performed in different orders. For example, the sub-sampled image data may be read twice at step 410 and pushed twice at step 420, thereby eliminating steps 430 and 440.
Although illustrative embodiments have been shown and described, a wide range of modification, change and substitution is contemplated in the foregoing disclosure and in some instances, some features of the embodiments may be employed without a corresponding use of other features. Those of ordinary skill in the art will appreciate that the hardware and methods illustrated herein may vary depending on the implementation. For example, although the disclosure is described in the context of rotating color images, this disclosure is not limited to use with display systems; rather, it envisions use of rotation of color images for all output devices including color printers. As an additional example, although the disclosure is described in the context of a single finite state machine (FSM), the controller may be implemented by deploying additional FSM's, with each FSM being dedicated to a particular function. As yet another example, although the disclosure is described in the context of YUV sub-sampled data, this disclosure is not limited to use with display systems incorporating YUV sub-sampling; rather it envisions any color space which may be sub-sampled.
The methods and systems described herein provide for an adaptable implementation. Although certain embodiments have been described using specific examples, it will be apparent to those skilled in the art that the invention is not limited to these few examples. The benefits, advantages, solutions to problems, and any element(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or an essential feature or element of the present disclosure.
The above disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments which fall within the true spirit and scope of the present invention. Thus, to the maximum extent allowed by law, the scope of the present invention is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.