The present disclosure relates generally to systems and methods of improving the viewing characteristics of electronic visual displays and, more particularly, to adjusting or correcting streaming video signals for improved viewing characteristics on such displays.
Signs are frequently used for displaying information to viewers. Such signs include, for example, billboards or other types of large outdoor displays, including electronic visual displays. Electronic visual displays or signs are typically very large, often measuring several hundred square feet in size. Electronic signs or displays have become a common form of advertising. For example, such displays are frequently found in sports stadiums, arenas, public forums, and/or other public venues for advertising diverse types of information. These displays are often designed to catch a viewer's attention and create a memorable impression very quickly.
The following disclosure describes systems and associated methods for processing or correcting streaming video to be shown on visual display signs, such as electronic visual displays. As described in detail below, a video correction system configured in accordance with one embodiment of the disclosure includes a first interface configured to receive a streaming video signal and to isolate individual display components or values of the streaming video signal (e.g., color components, such as red, green, and blue components). The first interface is coupled to a selection circuit that is configured to stream the display values to a multiplier according to clock signals associated with the corresponding display values. The system also includes a storage circuit that stores correction coefficients for the corresponding individual display values, and a fetch circuit that is coupled to the storage circuit. The fetch circuit retrieves the correction coefficients from the storage circuit and presents the correction coefficients to the multiplier along with the corresponding display values according to the associated clock signals. The system also includes a second interface coupled to the multiplier and configured to regroup individual corrected display values into a corrected streaming video. The second interface is further configured to communicate the corrected streaming video signal to an electronic display.
According to another embodiment of the disclosure, a method for correcting streaming video signals to be shown on a display includes receiving a streaming video signal with multiple display components. In one embodiment, these display components can include color components, such as, for example, red, green, and blue color components of a pixel of the streaming video signal. The method also includes isolating and transmitting the display components to a multiplier according to an associated clock signal for each of the display components. The method further includes fetching correction coefficients from a storage circuit. The correction coefficients correspond to individual display components. The method also includes presenting the correction coefficients to the multiplier along with the display components according to the associated clock signals, and adjusting the display components with the corresponding correction coefficients to form corrected display components of the streaming video signal. The method also includes collecting the adjusted display components into a corrected streaming video signal.
The methods and systems disclosed herein are configured to dynamically correct, calibrate, or otherwise adjust streaming video signals. More specifically, the correction coefficients of the embodiments described herein can be configured to achieve desired display characteristics of the streaming video signal after correcting or otherwise adjusting the streaming video signal with the correction coefficients. For example, and as described in detail below, the correction coefficients can be calculated or chosen to account for different input level signals of the input streaming video signal to achieve desired viewing characteristics of the streaming video signal. More specifically, the values of the retrieved correction coefficients can vary according to the values of the corresponding input level signals of the input streaming video signal.
Certain details are set forth in the following description and in
Many of the details, dimensions, angles, and other features shown in the Figures are merely illustrative of particular embodiments of the disclosure. Accordingly, other embodiments can have other details and features without departing from the spirit or scope of the present disclosure. In addition, those of ordinary skill in the art will appreciate that further embodiments of the disclosure can be practiced without several of the details described below.
The inventors have discovered that instead of making corrections to individual pixel signals, inventive hardware configurations and algorithms according to the present disclosure can be used to make corrections to composite video signals. The hardware and algorithmic embodiments described herein accordingly provide more efficient solutions than the conventional technology, and can also provide significant cost savings. For instance, since each LED or LED module of a display no longer needs to be individually corrected according to embodiments of the present disclosure, substantial cost savings in electronic circuitry may be realized.
In another example, since correction now may occur on a composite video signal according to embodiments of the present disclosure, the correction systems of the present disclosure may be placed at a more convenient location relative to the LED display than previously known. For example, in installations where the LED display is readily accessible, the correction hardware may be located directly adjacent to the display. In other installations, however, such as where the LED display may be mostly inaccessible (e.g., elevated on a tower or a building wall), the correction systems according to the present disclosure may be located at a substantially greater distance from the LED display.
In still another example, the correction systems according to the present disclosure may correct or otherwise process streaming video signals that can be wireless transmitted to a display sign. In these embodiments, regular maintenance of an LED display is simple and convenient because no correction needs to be performed at the site of the individual LEDs or modules.
In the illustrated embodiment, the pixel uniformity correction device 100 also includes conversion circuits or matching gamma decoder/encoder components 112, 114, source selection multiplexer components 116, 118, a static image generation component 120, a block memory component 122, a memory fetch circuit or interface component 124, a correction coefficient fetcher component 126 (e.g., such as a first-in first-out or “FIFO”), a multiplier component 128, a reconversion circuit or gamma decode/encode component 114, and a main processor or controller 130. It is understood that additional components, circuits, hardware, and/or software known to those skilled in the art may be incorporated in the correction device 100 but not shown or described herein to avoid unnecessarily obscuring aspects of the disclosure. Several of the features of the operation and interaction of the components of the correction device 100 are described in detail below.
In the illustrated embodiment, the correction device 100 is configured to apply correction coefficients to display values or components (e.g., color or luminance components) of the streaming video signal for the purpose of providing the corrected or adjusted streaming video signal. This corrected streaming video signal is calibrated such that the display that shows the corrected streaming video has a desired appearance or desired display properties. Suitable methods and systems for determining correction coefficients or factors are disclosed in U.S. patent application Ser. No. 10/455,146, entitled “Method and Apparatus for On-Site Calibration of Visual Displays,” filed Jun. 4, 2003, and U.S. patent application Ser. No. 10/653,559, entitled “Method and Apparatus for On-Site Calibration of Visual Displays,” filed Sep. 2, 2003, each of which is incorporated herein by reference in its entirety.
In the embodiment illustrated in
In operation, a streaming digital video signal source or DVI source provides the video signal 106a to the first interface 108. The first interface 108 performs such tasks as signal level matching, signal equalization, signal isolation, electrostatic discharge protection, and the like. More specifically, the first interface 108 can isolate display values or components into an isolated input signal 132a. The isolated input signal 132a can accordingly include isolated display values or components, such as color values and/or luminance values, for each pixel of a displayable image represented in the video stream signal 106a. For example, these isolated display values can represent gray values for each of the three primary light colors: red, green, and blue (RGB) of the streaming video signal 106a. In addition, the first interface 108 separates the isolated input signal 132a (e.g., the raw DVI format signal) from an associated clock signal p_clk. Both the isolated input signal 132a and the clock signal p_clk are propagated to the gamma decoder 112.
Because the luminance values of the streaming video signal 106a will not be reproduced linearly by the display, the gamma decoder 112 converts the display values or components into a linear space for each pixel of a displayable image represented in the video stream signal 106a for further processing. More specifically, the streaming video signal 106a in the embodiment of
In addition to or in place of the input video stream signal 106a, the pixel uniformity correction device 100 may also generate a signal with the static image generator 120. The static image generator 120 is configured to produce a static image stream 136 that comprises a bit-wise structure similar in form to the decoded video stream 134a. The static image generator 120 also produces a generated clock signal gen_p_clk. For example, a video stream of static images 136 can be represented by 24-bit RGB luminance values corresponding to each pixel of a displayable image. In addition, the static image stream 136 can also have control bits corresponding to the control bits produced by the gamma decoder 112.
Typically, the static image generator 120 is used for testing and calibration of LED displays. For example, the static image generator can generate signals representing solid screens of individual RGB colors that can be streamed through the pixel uniformity correction device 100 for observation on a display or sign to calibrate or otherwise adjust the display properties of the output. In the embodiment illustrated in
The fast multiplier 128 receives the video streams from the multiplexers 116, 118 to apply the correction coefficients to these video streams. For example, the fast multiplier 128 can receive the selected video stream 138 from the first multiplexer 116, and the selected clock signal 139 from the second multiplexer 118. To properly correct LED display pixels, each of the display values, such as the RGB luminosity values, is adjusted with an associated set of correction coefficients. The fast multiplier 128 is the component of the correction device 100 that performs the adjustment of the display values according to the correction coefficients.
The correction coefficients that the correction device 100 applies to the streaming video signal can be configured to dynamically correct, calibrate, or otherwise adjust the streaming video signal. For example, the correction coefficients can be selected or calculated to account for different input levels of the inputs streaming video signal to achieve desired display characteristics of the streaming video signal after correcting or otherwise adjusting the streaming video signal with the correction coefficients. More specifically, in certain embodiments, the correction coefficients can be configured to correct the streaming video signal to produce the output streaming video signal that will be shown with generally uniform display characteristics or properties (e.g., with generally uniformity across the LED pixels of the display). In other embodiments, however, uniform display characteristics may not be desired. For example, in certain cases a user may want to show a streaming video on a display according to the full brightness of the display, at a sacrifice of the uniformity of the display. As such, the correction coefficients that are applied to the streaming video signal can accordingly adjust or otherwise condition the signal such that the output streaming video signal will be shown on the display according to the desired full brightness of the display. In other embodiments, the correction coefficients can be selected to achieve other display characteristics other than full brightness of the display. As such, the values of the retrieved correction coefficients can vary according to the values of the corresponding input level signals of the input streaming video signal.
As illustrated in
The main controller 130 is configured to direct the operation of the pixel uniformity correction device 100. For example, the main controller 130 keeps track of the progress of the selected video stream 138 and directs the memory fetch interface 124 to retrieve particular correction coefficients from block memory 122. The memory fetch interface 124 negotiates bus traffic, retrieves the directed coefficients, and supplies the correction coefficients to the coefficient FIFO 126.
The coefficient FIFO 126, which shares the selected clock signal 139 from the second multiplexer 118, cooperatively provides correction coefficients to the fast multiplier 128. Accordingly, the correction FIFO 126 provides the correction coefficients to the multiplier 128 in a manner that corresponds with the display values passed to the multiplier 128. Within the multiplier 128, which may be integrated with main controller 130, matrix calculations take place to adjust the display values of the selected video stream 138, such as the RGB luminosity values of the selected video stream 138. For example, the multiplier 128 can adjust each 16-bit RGB value of the selected data stream 138 by multiplying the 16-bit value with three corresponding correction coefficients, one each for RGB. In one embodiment, each of the correction coefficients can be 12 bits. In other embodiments, however, each of the coefficients can be greater than or less than 12 bits. The output of multiplier 128 is an adjusted or corrected streaming video signal 134b having the same bit-wise constitution of the input signal, but having adjusted or corrected display values.
At this point, although the adjusted video stream 134b includes the correction factors for the corresponding display values, the adjusted video stream 134b needs to be re-encoded or re-converted into a digital video signal format. As such, the gamma encoder 114 performs the forward gamma conversion to re-encode the adjusted video stream 134b into its original gamma space as the adjusted or corrected re-encoded signal 132b. The second interface 110 transmits the corrected and re-encoded video signal 132b back onto a communications medium as a corrected streaming video signal 106b.
The correction device 100 can also be configured to account for the resolution and display capabilities of the display that will ultimately show the corrected streaming video signal 106b. In certain embodiments, for example, an output port of the correction device 100 can be configured to read Extended Display Identification Data (EDID) from the display that will show the streaming video signal. The correction device 100 can store the EDID to memory coupled to the input port of the correction device 100, such as, for example, EEPROM coupled to the input port. Moreover, in still further embodiments, and as described in detail below with reference to
Further details are described below regarding the processing of the pixels (e.g., pixels from the video stream signal) through the pixel uniformity correction device 100 illustrated in
At a second phase, the pixel is run through a data enable generator, which uses the framing signals to generate a data enable pulse when the pixel is intended to be interpreted as a valid pixel. This data enable pulse is then transmitted with the rest of the pixel for the remainder of the pixel processing. The pixel color components are not altered at this stage.
At a third phase, the pixel then undergoes a reverse gamma calculation within the gamma decoder 112. The level of reverse gamma calculation may be set by the user. The core is configured by the main processor 130, for example a Xilinx MicroBlaze processor, across a PLB bus. Although most displays have gamma correction, in certain embodiments, reverse gamma calculations may not be needed. However, even if the reverse gamma calculations were not required, the pixels may still be converted from 8 bit to 16 bit via a lookup table, such as a linear lookup table for example, if no gamma correction is used.
At a fourth phase, the pixel uniformity correction device 100 has the ability to produce its own source pixels for the purpose of driving test patterns onto the display or sign. These test patterns, which are generated by the static image generator 120, are used to assist in data collection necessary to produce coefficient data for a display. During normal operation, however, the static image generator 120 is disabled and pixels from the gamma decoder 112 are not affected by the static image generator.
At a fifth phase, the pixel is transformed by the correction coefficients stored in the memory block 122. The nine transforming correction coefficients are expressly correlated to a specific pixel position in the output display. Each correction coefficient in the embodiment of
Further at the fifth phase, the multiplication step can be performed in a three state pipeline. At stage 1, incoming coefficients are latched and pixel data is latched. This helps improve timing into the multipliers. At stage 2, each color value is multiplied by the individual color coefficients. For example the first row of the matrix, which adjusts the red value of the targeted pixel, would produce the following 3 values of Equations 3-5:
Coef00×Rinput=Rapplied0 Equation 3
Coef01×Ginput=Gapplied0 Equation 4
Coef02×Binput=Bapplied0 Equation 5
At stage 3, the color components of each row are added to form the new red color component for that row. That is:
Rapplied0+Gapplied0+Bapplied0=Radjust Equation 6
At a sixth phase, if necessary, the adjusted pixel undergoes gamma readjustment at the gamma encoder 114. This re-adjustment applies a complementary transform to that which was applied by the gamma decoder 112 during the reverse gamma calculations. Moreover, in the rare instances where the gamma correction is not required, the adjusted pixels are still converted from 16 bit back to 8 bit with a forward gamma conversion via a lookup table.
At a seventh phase, the adjusted pixel is sent through the second interface 110, such as a TFP410, which is a DVI output PHY, to transmit the pixel out of the pixel uniformity correction device 100. At this point, the pixel, which is one pixel in the video stream, may be transmitted to the display or may undergo further processing.
In certain embodiments, the streaming video data signal includes large quantities of pixel data. The correction device 100 can store corresponding correction coefficients and repeatedly fetch the correction coefficients from the memory block 122 by the memory fetch interface 124. In certain embodiments, limitations of the memory controller may require at least one correction coefficient fetch interface 124 for every 2 correction coefficient FIFOs 126. Moreover, the fetch interfaces 124 can used in burst mode to issue large read burst commands into the memory controller associated with memory block 122, and push the retrieved data into the correction coefficient FIFOs 126. In addition, for fetch interfaces 124 that serve multiple FIFOs 126, an alternating read burst strategy may be used. For example, the function of the FIFOs 126 can be configured to hold burst data from the fetch interfaces 124, and then to serve the data cooperatively into the multiplier circuit 128 where the correction coefficients are applied to the corresponding display values. This operation performs similar to a leaky bucket algorithm used in network communications.
With reference to
More specifically, and with reference to
Accordingly, when the corrected streaming video signal is subsequently scaled according to the display scaling factor after exiting the correction device, the streaming video signal will have the appropriate one-to-one correspondence between the video stream and the physical pixels of the display. In other embodiments, however, such as when the streaming video signal will not be scaled after exiting the correction device, the correction device can still scale the video signal according to a desired scale factor without having to unscale the streaming video signal according to the initial scaling factor. Rather, the correction device can output the corrected streaming video signal at the desired scale factor for display on a sign.
From the foregoing, it will be appreciated that specific embodiments of the disclosure have been described herein for purposes of illustration, but that various modifications may be made without deviating from the spirit and scope of the various embodiments of the disclosure. For example, although the display values are described above as converted from 8 bits to 16 bits, in other embodiments these display values can be converted to bit values other than 16 bits. Further, while various advantages associated with certain embodiments of the disclosure have been described above in the context of those embodiments, other embodiments may also exhibit such advantages, and not all embodiments need necessarily exhibit such advantages to fall within the scope of the disclosure. Accordingly, the disclosure is not limited, except as by the appended claims.
This application claims the benefit of U.S. Provisional Application No. 61/158,273, entitled METHOD AND APPARATUS FOR PIXEL UNIFORMITY CORRECTION, filed Mar. 6, 2009, which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5161017 | Sato | Nov 1992 | A |
5430486 | Fraser et al. | Jul 1995 | A |
7907154 | Rykowski et al. | Mar 2011 | B2 |
7911485 | Rykowski et al. | Mar 2011 | B2 |
Number | Date | Country | |
---|---|---|---|
20100225819 A1 | Sep 2010 | US |
Number | Date | Country | |
---|---|---|---|
61158273 | Mar 2009 | US |