1. Field of the Invention
This invention relates generally to computer systems and more particularly to a method and apparatus for converting between various color space formats.
2. Description of the Related Art
Current liquid crystal display (LCD) controller designs incorporate display buffers that only support display data in RGB format. As is generally known, RGB format display data varies in color depth from 8, 16, or 24 bit-per-pixel (bpp). Newer LCD controllers incorporating digital video features, such as video input ports, JPEG, and MPEG functionality, require 16 or 24 bpp color depths to properly display live video or still images. Typically, the display data coming from various modules are converted to RGB format before storage into the display buffer.
For current generations of LCD controllers that support a camera interface and a JPEG CODEC, incoming YUV data from these modules are first converted to 16 bpp or 24 bpp (unpacked 32-bits wide) RGB data format by a YUV-RGB Converter (YRC). The converted data is then stored in the display buffer. In order to convert between YUV/Y′CbCr data (digital video signal format) and RGB data (display data format) and vice versa, a YRC (YUV-RGB. Converter) or RYC (RGB-YUV Converter) is used. These converters use the standard equations for converting between these two formats.
As a result, there is a need to solve the problems of the prior art to provide a color space conversion system and method that may linearly adjust the input to and the output from the conversion matrix independent of the color look up table efficiently.
Broadly speaking, the present invention fills these needs by providing a method and apparatus for color space conversion where the color space conversion values are programmable via a register setting. It should be appreciated that the present invention can be implemented in numerous ways, including as a process, a system, or a device. Several inventive embodiments of the present invention are described below.
In one embodiment, a method for converting between color space formats is provided. The method initiates with identifying a first color space format. Then, both an offset parameter and a scale parameter are selected. The offset parameter and the scale parameter are associated with the first color space format. A conversion matrix configured to convert values associated with the first color space format to a second color space format is identified. When to apply the offset parameter and the scale parameter in relation to application of the conversion matrix is determined, i.e., to the input for the conversion matrix or to the output from the conversion matrix.
In another embodiment, a computer readable medium having program instructions for converting between color space formats is provided. The computer readable medium includes program instructions for identifying a first color space format. Program instructions for selecting both an offset parameter and a scale parameter associated with the first color space format are provided. Program instructions for identifying a conversion matrix configured to convert values associated with the first color space format to a second color space format and program instructions for determining when to apply the offset parameter and the scale parameter in relation to application of the conversion matrix are included.
In yet another embodiment, a display controller is provided. The display controller includes an input port configured to receive video data from an external device. The display controller also includes a programmable register block configured to store color space conversion factors and a color space conversion block configured toe convert the video data between color space formats. The color space conversion block is capable of applying the color space conversion factors to an input to the color space conversion block and/or an output from the color space conversion block. The application of the color space conversion factors are based upon a type of color format associated with the received video data.
In another embodiment, an integrated circuit is provided. The integrated circuit includes circuitry for storing color space conversion factors. The color space conversion factors include matrix conversion factors, scaling factors and offset factors. Circuitry for receiving video input data associated with a first color space format is provided. Circuitry for applying selected color space conversion factors to the received video input data is included. The circuitry for applying selected color space conversion factors includes circuitry for adjusting a contrast characteristic of the video input data, and circuitry for adjusting a brightness characteristic of the video input data. Circuitry for applying a conversion matrix to convert the input video data to a second color space format is included in the circuitry for applying selected color space conversion factors, wherein the conversion to the input data occurs after either the contrast characteristic or the brightness characteristic have been adjusted.
Other aspects and advantages of the invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, illustrating by way of example the principles of the invention.
The present invention will be readily understood by the following detailed description in conjunction with the accompanying drawings, and like reference numerals designate like structural elements.
An invention is described for an apparatus and method for converting between various color space formats through programmable registers containing the color space conversion factors. It will be apparent, however, to one skilled in the art, in light of this disclosure, that the present invention may be practiced without some or all of these specific details. In other instances, well known process operations have not been described in detail in order not to unnecessarily obscure the present invention.
The embodiments of the present invention provide a color space conversion scheme accomplished through the use of programmable registers having the associated color space conversion factors. Thus, the embodiments described herein provide for the implementation of a color space conversion (CSC) block having each conversion coefficient, scaling value, and offset value programmable via a register setting. In one embodiment, a total of 21 registers require programming for the full functionality of the color space conversion block. One skilled in the art will appreciate that since the conversion coefficients are not hard coded, the multiple YUV-RGB or RGB-YUV conversion coefficient values need not be implemented, thereby decreasing the block size to conserve valuable chip real estate. As will be explained in more detail below, the programmable offset and scale parameters implemented through the registers provide additional linear adjustment to the input or output of the CSC block, e.g., camera video or JPEG CODEC output adjustment, independent of the display frame buffer color look-up table (LUT). Consequently, the adjusting of the LUT, which requires reprogramming of up to 256 registers and affects the entire display, is avoided. That is, rather than reprogramming the LUT, changing three registers accomplishes the desired linear adjustment.
In one embodiment, the color space conversion module 130-1 utilizes the equation discussed with reference to
In another embodiment, display controller 120 of
It should be appreciated that the embodiments described herein allow for much more user control of the color space conversion. Furthermore, the conversion may be defined between various color space formats including but not limited to YUV (or Y′CbCr) to RGB or RGB to YUV (or Y′CbCr) by simply reprogramming the Xsubscript′ Ysubscript′ Zsubscript coefficients. As mentioned above, the programmable offset and scale parameters implemented by registers provide additional linear adjustment to the input or output of the CSC block (camera video or JPEG CODEC output adjustment) independent of display frame buffer color look-up table (LUT). In addition, adjusting the LUT requires reprogramming up to 256 registers and affects the entire display. For example, if programmed as a YRC, changes to values Aoff, Boff, and Coff allows brightness and hue manipulation. Changes to Ascale, Bscale, and Cscale allows contrast and saturation manipulation, while changes to values of Xoff, Yoff, Zoff allows RGB color balance manipulation. In one embodiment, the color space matrix output, X, Y or Z, may be fixed to a desired value by programming “0” in the corresponding Xscale, Yscale, and Zscale registers, i.e., for gray scale UV is fixed to 80 h. Thus, the CSC X, Y, Z output values could then be fixed to the values programmed in registers Xoff, Yoff or Zoff. In another embodiment, CSC conversion may be bypassed by programming “0” in the matrix register, except for the matrix diagonals Xa, Yb, and Zc, and by programming the Scale Registers, both of which are programmed “1.”
Tables 1 and 2 illustrate exemplary settings for YUV to RGB conversion (YRC) and RGB to YUV (RYC) conversion, respectively.
As illustrated in Tables 1 and 2, the configuration of the conversion scheme enables the input to and the output from the conversion matrix to be adjusted independent of the LUT. For example, to adjust the brightness, three register values are changed rather than changing an entire LUT. Therefore, the color conversion scheme defined herein may selectively apply and modify scale and offset parameters before or after the application of a conversion matrix. That is the input data may be scaled and offset prior to conversion and/or the output data may be scaled and offset after conversion. In addition, the scale parameters may be applied independently of the offset parameters for either the input or output. Furthermore, in order to adjust the input scale and offset, there is no need to adjust the matrix coefficients with respect to the embodiments described herein.
In summary, the above-described embodiments enable independent application for offset and scaling operations which may be applied before or after a matrix calculation. Furthermore, the independent application of the offset and scaling operations to the input occur without having to recalculate or otherwise change the matrix coefficients. It should be appreciated that the above described embodiments may be incorporated into any suitable display controller. In one embodiment, the display controller discussed in application Ser. No. ______ (Attorney Docket No. VP087) which has been incorporated by reference, includes the color space conversion scheme provided herein.
With the above embodiments in mind, it should be understood that the invention may employ various computer-implemented operations involving data stored in computer systems. These operations are those requiring physical manipulation of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. Further, the manipulations performed are often referred to in terms, such as producing, identifying, determining, or comparing.
Any of the operations described herein that form part of the invention are useful machine operations. The invention also relates to a device or an apparatus for performing these operations. The apparatus may be specially constructed for the required purposes, or it may be a general purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data which can be thereafter read by a computer system. The computer readable medium also includes an electromagnetic carrier wave in which the computer code is embodied. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, CD-ROMs, CD-Rs, CD-RWs, magnetic tapes, and other optical and non-optical data storage devices. The computer readable medium can also be distributed over a network coupled computer system so that the computer readable code is stored and executed in a distributed fashion.
The above described invention may be practiced with other computer system configurations including hand-held devices, microprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers and the like. Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
This application is related to U.S. patent application Ser. No. ______ (Attorney Docket No. VP087), filed on the same day as the instant application and entitled “YUV DISPLAY BUFFER.” This application is hereby incorporated by reference in its entirety for all purposes.