In display systems employing spatial light modulators, the OFF-state light from OFF-state pixels of the spatial light modulator can be captured and directed back to the pixels of the spatial light modulator so as to recycle the OFF-state light in the display system. Bitplanes derived from the desired image to be produced are calibrated to include the recycled off-state light to properly produce the desired image using the display system.
|
1. A method of allocating display times comprising:
representing image data for an image to be displayed during a frame time as a sequence of one or more bit planes for one or more colors;
calculating a recycling gain for each bit plane;
compressing each bit plane based on the recycling gain;
determining an unused portion of the frame time based on the compressed bit planes; and
stretching the bit planes to utilize the unused portion of the frame time.
8. A method of allocating display times comprising:
receiving image data for an image to be displayed during a frame time using one or more primary colors;
converting the image data to a sequence of bit planes for a set of colors including the primary colors and secondary colors;
calculating a recycling gain for each bit plane;
compressing each bit plane based on the recycling gain;
determining an unused portion of the frame time based on the compressed bit planes; and
stretching the bit planes to utilize the unused portion of the frame time.
4. The method of
5. The method of
receiving the image data representing an input set of colors; and
converting the image data to image data representing the one or more colors.
6. The method of
7. The method of
10. The method of
11. The method of
|
This application is a divisional of application Ser. No. 11/782,897, filed Jul. 25, 2007 which claims the benefit of provisional Application No. 60/909,877, filed Apr. 3, 2007 and is a continuation-in-part of application Ser. No. 11/696,033, filed Apr. 3, 2007, now U.S. Pat. No. 7,876,340.
This US patent application claims priority under 35 U.S.C. 119(e) of provisional US patent application “A PULSE WIDTH MODULATION ALGORITHM” to Russell, Ser. No. 60/909,877 filed Apr. 3, 2007; and this US patent application is a continuation-in-part of co-pending US patent application “A PULSE WIDTH MODULATION ALGORITHM” to Russell, Ser. No. 11/696,033, filed Apr. 3, 2007. The subject matter of each is incorporated herein by reference in its entirety.
This US patent application is also related to US patent application “OFF-STATE LIGHT RECAPTURING IN DISPLAY SYSTEMS EMPLOYING SPATIAL LIGHT MODULATORS” to Russell, Ser. No. 11/696,044 filed Apr. 3, 2007, the subject matter of which is incorporated herein by reference in its entirety.
The technical field of the examples to be disclosed in the following sections relates to the art of display systems, and more particularly, to pulse-width-modulation techniques for use in display systems employing spatial light modulators.
In current imaging systems that employ spatial light modulators composed of individually addressable pixels, a beam of incident light is directed to the pixels of the spatial light modulator. By setting the pixels at an ON state, the incident light is modulated onto a screen so as to generate bright image pixels on the screen, wherein such modulated light is referred to as the ON-state light; and the pixels at the ON state are referred to as ON-state pixels. By setting the pixels at an OFF state, the incident light is modulated away from the screen so as to cause dark pixels on the screen, wherein such modulated light is referred to as OFF-state light; and the pixels at the OFF state are referred to as OFF-state pixels. For obtaining a high contrast ratio, the OFF-state light is dumped or discarded by the imaging systems, which on the other hand, reduces the optical efficiency of the imaging system.
In one example, a method for displaying an image is disclosed herein. The method comprises: directing a beam of incident light onto an array of pixels of a spatial light modulator, wherein each pixel is capable of being operated at a first state and a second state; modulating the beam of incident light into a first portion of light by pixels at the first state and a second portion of light by the pixels at the second state based on a set of bitplanes, further comprising: displaying each bitplane by the pixels for a time period that is determined based on a number of pixels in said each bitplane that cause the pixels of the spatial light modulator to the second state; directing the first portion of light from the spatial light modulator onto a display target, and the second portion of light from the spatial light modulator away from the display target; and recycling the second portion of light back to the pixels of the spatial light modulator.
In another example, a device for use in a display system employing a spatial light modulator having an array of pixels with each pixel capable of being operated at a first state and a second state that is different from the first state is disclosed herein. The device comprises: first means for deriving the bitplanes based on a sequence of color duty cycles; and second means for determining a clock speed at which the spatial light modulator is to be operated in displaying the bitplanes based on a number of off-states in each bitplane.
In yet another example, a display system is disclosed herein. The system comprises: a light source capable of providing a light beam; a spatial light modulator having an array of individually addressable pixels each being capable of modulating the light beam into a first portion of light when said each pixel is at a first state and a second portion of light when said each pixel is at a second state based on a set of bitplanes; a light recycling mechanism capable of recycling the second portion of light back to the spatial light modulator; and a system controller for controlling an operation of the spatial light modulator, further comprising a device that comprises: a bitplane module for deriving the bitplanes based on a sequence of color duty cycles; and a clock speed calculator in connection to the bitplane module for determining a clock speed at which the spatial light modulator is to be operated in displaying the bitplanes based on a determination of an amount of light to be recycled by the light recycling mechanism in displaying at least one of the derived bitplanes.
In still yet another example, a method for displaying a color image composed of a set of color image components is disclosed herein. The method comprises: directing a sequence of light beams of different colors to an array of pixels of a spatial light modulator; at a time when one of the light beams of a color is illuminating the spatial light modulator, modulating said one of the light beams into a first portion of modulated light and a second portion of modulated light by the pixels of the spatial light modulator; directing the first portion of modulated light onto a display target; and recycling at least a part of the second portion of the modulated light back to the pixels of the spatial light modulator.
In yet another example, a method for displaying an image is disclosed herein. The method comprises: directing a beam of light on an array of pixels of a spatial light modulator; modulating said beam of light by the pixels of the spatial light modulator into modulated light based on a modified bitplane; recycling at least a part of the modulated light back to the pixels of the spatial light modulator; and wherein said modified bitplane is obtained by a process comprising: deriving a bitplane from the image; and modifying the derived bitplane such that a first pixel of the derived bitplane is modified in a differently from a second pixel of the derived image.
In yet another example, a method of displaying a color image frame is disclosed herein. The method comprises: defining a set of colors comprising first and second colors for representing the color image frame; obtaining an energy distribution of the color image frame in the set of colors; re-distributing the energy in the set of colors by moving the energy of the first color into the energy of the second color; and displaying the image frame based on the re-distributed energy in set of colors.
In yet another example, a display system is disclosed. The system comprises: a light source capable of providing a light beam; a spatial light modulator having an array of individually addressable pixels each being capable of modulating the light beam into a first portion of light when said each pixel is at a first state and a second portion of light when said each pixel is at a second state based on a set of bitplanes; a light recycling mechanism capable of recycling the second portion of light back to the spatial light modulator; and a system controller for controlling an operation of the spatial light modulator, further comprising: a data formatter capable of converting the pixel data of the input image into the set of bitplanes; an average pixel calculator having an input connected to the input image for calculating an average pixel value of the input image; a real-time bit counter having an input coupled to the bitplanes for calculating a number of pixels in each bitplane that cause the pixels of the spatial light modulator to be at the second state; a clock speed calculator having a set of inputs connected to an output of the average pixel value calculator and an output of the real-time bit counter for calculating a clock speed based on the calculated average pixel data value and said number of pixels in each said bitplane; a clock speed adjustor having an input connected to an output of the clock speed calculator and an input coupled to a sequence of clock signals of the spatial light modulator provided by a clock of the display system; and a controller having an input connected to an output of the clock speed adjustor for operating the spatial light modulator at the adjusted clock speed.
In yet another example, a method for displaying a sequence of image frames using an array of individually addressable pixels of a spatial light modulator is disclosed. The method comprises: deriving a set of bitplanes from each image frame, wherein each bitplane has an index representing a relative position of the bitplane in the set of bitplanes; modulating, by the pixels of the spatial light modulator, a beam of incident light into ON-state and OFF-state light based on the bitplanes, further comprising: displaying a first bitplane of a first set of bitplanes derived from a first image frame of the image sequence that is displayed by the pixels of the spatial light modulator for a first time period; displaying a second bitplane of a second set of bitplanes derived from a second image frame of the image sequence that is displayed by the pixels of the spatial light modulator for a second time period; and wherein the first and second bitplanes have the same index; and the first and second time periods are different; directing the OFF-state light away from a display target and the ON-state light onto the display target; and re-routing the OFF-state light back to the pixels of the spatial light modulator.
In yet another example, a method for displaying an image is disclosed herein. The method comprises: directing a beam of light on an array of pixels of a spatial light modulator; modulating said beam of light by the pixels of the spatial light modulator into modulated light based on a modified bitplane; recycling at least a part of the modulated light back to the pixels of the spatial light modulator; and wherein said modified bitplane is obtained by a process comprising: deriving a bitplane from the image; and modifying the derived bitplane such that a first pixel of the derived bitplane is modified in a differently from a second pixel of the derived image.
In a typical existing display system employing a spatial light modulator, ON-state light from ON-state pixels of the spatial light modulator propagates towards the screen of the display system so as to generate a bright image pixel on the screen. The off-state light from off-state pixels of the spatial light modulator travels away from the screen so as to result in a dark pixel on the screen. Such off-state light is often dumped or discarded by the display system, which reduces the optical efficiency of the display system.
As an aspect of this disclosure, a mechanism for recycling the off-state light is provided, as will be discussed in the first part of this disclosure. Because most current display systems employing spatial light modulators operate based on bitplanes; and the bitplanes may cause different number of pixels at the OFF-state, the intensity of the recycled off-state light varies over time or over bitplanes. Such variation, in turn, causes distortion of the displayed image. This problem can be solved by calibrating the set of bitplanes derived from the desired image to include the energy of the recycled off-state light, as will be discussed in the second part of this disclosure. This problem can alternatively be solved by displaying the bitplanes derived from the desired image at dynamically adjusted clock speed, as will be discussed in the third part of this disclosure.
Off-State Light Recycling Mechanism
The off-state light from off-state pixels at a time can be captured and rerouted back to the pixels of the spatial light modulator. The rerouted off-state light, when illuminating the on-state pixels of the spatial light modulator, is converted to the ON-state light that can be projected to the screen so as to increase the brightness of the projected image. When illuminating the off-state pixels, the rerouted off-state light will be re-captured and then rerouted again to the pixels of spatial light modulator. This off-state light capturing and rerouting process is referred to as “off-state light recycling.” A device having the capability of off-state light recycling in display systems is referred to as an off-state light recycling mechanism.
As an example,
Light source 102 provides light for the imaging system. The light source may comprise a wide range of light emitting devices, such as lasers, light-emitting-diodes, arc lamps, devices employing free space or waveguide-confined nonlinear optical conversion and many other light emitting devices. In particular, the light source can be a light source with low etendue, such as solid state light emitting devices (e.g. lasers and light-emitting-diodes (LEDs)). When solid-state light emitting devices are used, the light source may comprise an array of solid-state light emitting devices capable of emitting different colors, such as colors selected from red, green, blue, and white. Because a single solid-state light emitting device generally has a narrow characteristic bandwidth that may not be optimal for use in display systems employing spatial light modulators, multiple solid-state light emitting devices can be used for providing light of each color so as to achieve optimal bandwidth for specific display systems. For example, multiple lasers or LEDs with slightly different characteristic spectra, such as 20 nm or less characteristic wavelength separation, can be used to produce a color light such that the characteristic spectra of the multiple lasers or LEDs together form an optimal spectrum profile of the display system. Exemplary laser sources are vertical cavity surface emitting lasers (VCSEL) and Novalux™ extended cavity surface emitting lasers (NECSEL), or any other suitable laser emitting devices.
Spatial light modulator 108 comprises an array of individually addressable pixels for spatially modulating the incident light onto or away from projection lens 110 that projects the modulated light onto screen 112 so as to reproduce images. The spatial light modulator may comprise pixels of many different natures, such as reflective and deflectable micromirrors and liquid-crystal-on-silicon (LCOS) devices. The pixels can be operated using binary or non-binary modes. In the binary mode, each pixel is switched between an ON and OFF state. At the ON state, each pixel modulates the incident light onto the projection lens (110). At the OFF state, each pixel modulates the incident light away from the projection lens. The ON-state light arrives at the screen (112) so as to construct the desired image; and the OFF-state is recycled by off-state light recycling mechanism 104 and redirected to the spatial light modulator, which will be discussed afterwards. The pixels of the spatial light modulator alternatively can be operated at a non-binary mode, such as an analog mode wherein multiple intermediate states are defined between an ON and OFF state; and the intermediate states may or may not be continuous between the ON and OFF states. In either binary or non-binary operation mode, color and gray images can be produced using a pulse-width-modulation technique, examples of which will be discussed afterwards.
OFF-state light recycling mechanism 104 is optically coupled to the propagation path of the off-state light that is modulated from the pixels of the spatial light modulator (108) such that the off-state light from the pixels at the OFF state of the spatial light modulator can be recaptured by the off-state light recycling mechanism. For redirecting the recaptured off-state light back to the pixels of the spatial light modulator, the OFF-state light recycling mechanism has a light exit end that is aligned to the propagation path of the incident light to the pixels of the spatial light modulator.
In the example illustrated in
Because the OFF-state light from the spatial light modulator can be recaptured and redirected to the spatial light modulator, this recycling process improves the brightness of images produced on the screen. Such brightness improvement can be mathematically described as brightness gain as expressed in equation 1:
In equation 1, G is the brightness gain due to OFF-state light recycling; I is the illumination intensity of light arriving at the screen including the recycled OFF-state light; and Io is the illumination intensity of light arriving at the screen without OFF-sate light recycling. ε is the OFF-state light recycling efficiency that is defined as the fraction of the OFF-state light that re-illuminates the pixels of the spatial light modulator after a recycling process, compared to the total amount of OFF-state light to be recycled by the recycling process. x is the normalized number of ON-state pixels of the spatial light modulator at a time (e.g. during a bitplane time). Specifically, x can be expressed as equation 2:
wherein NON is the number of ON-state pixels at a time; and Ntotal is the total number of pixels involved in modulating the incident light. It is noted that Ntotal may or may not be the total number of pixels of the spatial light modulator, especially when the spatial light modulator comprises active and inactive pixel areas. Pixels in inactive pixel areas of spatial light modulators are those pixels whose states in image display operations are independent from the data (e.g. bitplane data) derived from desired images; whereas pixels in active pixel areas are those whose states are associated with or determined by the image data.
Recycling efficiency ε is primarily determined by the optical design of the off-state light recycling mechanism and the optical coupling of the off-state light recycling mechanism to the display system, particularly to the propagation path of the OFF-state light from the spatial light modulator and the propagation path of the light incident to the spatial light modulator. Ideally, ε is 100%. In practice, ε may be less than 100% due to imperfect optical coupling of the off-state light recycling mechanism to the propagation path of the off-state light from the spatial light modulator and/or to the propagation path of the incident light to the spatial light modulator and/or due to light leakage from imperfect optical design of the off-state light recycling mechanism. To maximize the brightness gain, it is preferred that ε is maximized. In other examples, however, maximizing off-state light recycling may be impeded by other preferred system features, which results in balance between off-state recycling and the preferred features. For example, the off-state light recycling mechanism and/or the system design is desired to be cost-effective or desired to be volume compact or other reasons, poor ε may be selected. In any instances, it is preferred that ε is 10% or more, such as 20% or more, 30% or more, 40% or more, 50% or more, 60% or more, and 70% or more. As an example, table 1 shows the brightness gain achieved from different fractions of ON-state pixels (which can be converted to the number of ON-state pixels using equation 2) by assuming that the recycling efficiency ε is 60%.
TABLE 1
% of ON-state pixels
0
10
20
30
40
50
60
70
80
90
100
Brightness
2.5
2.17
1.92
1.72
1.56
1.43
1.32
1.22
1.14
1.06
1
gain
An exemplary variation of the maximum gain with the recycling efficiency is presented in
As can be seen in
Because the gain is due to the off-state recycling, the amount of gain obtained through off-state recycling depends on the number of off-state pixels of the spatial light modulator during the recycling process. As an example,
In addition to the brightness improvement as discussed above, the off-state light recycling has many other benefits. For example, the off-state recycling can also be used to increase the lifetime of the light source of the imaging system and/or to reduce the power consumption of the imaging system. Specifically, the light source can be operated as a lower power, as compared to imaging operations without off-state light recycling, during imaging operations but without sacrificing the brightness of the reproduced images. Operating the light source at reduced power certainly helps to increase lifetime of the light source, especially solid-state light sources, such as lasers and LEDs. Moreover, reduced power also reduces heat generated by the light source, which in turn increases lifetime of other components in the system by for example, reducing the commonly existing aging effect.
The off-state light recycling mechanism (104) as illustrated in
Optical diffuser 130 is provided herein for homogenizing the light beam incident thereto and transforming the incident light beam, especially narrow-band or narrow-angle light beans from solid-state light emitting devices, into light beams with pre-determined illumination field profiles. A narrow-angle light beam is referred to a light beam with a solid-angle extension of 5 degrees or less, such as 2 degrees or less, 1 degree or less, 0.5 degree or less, and 0.2 degree or less. The homogenization capability of the optical diffuser is enabled by randomly or regularly deployed scattering centers. The scattering centers can be located within the body of the diffuser or in (or on) a surface(s) of the diffuser, which constitute the features responsible for directing the incident light into various spatial directions within the spread of the optical diffuser. Depending upon different locations of the scattering centers, the optical diffuser can be a volume optical diffuser where the scattering centers are within the bulk body of the diffuser, or a surface diffuser where the scattering centers are on the surface of the bulk body of the diffuser. In one example, the optical diffuser can be a surface diffuser, such as a standard engineered diffuser. Even though not required, the optical diffuser can be used when the light source (102 in
The optical integrator (132) comprises opening 136 formed in end wall 134 of the optical integrator. Side wall 134 has interior surface coated with a reflective layer for reflecting the light incident thereto. In particular, the interior surface of side wall 134 is used to reverse the direction of the incident light such that the off-state light recaptured at the other end (138) of optical integrator 132 can be bounced back to travel towards the spatial light modulator. For this purpose, the reflective layer coated on the interior surface of side wall 134 can be a totally-internally-reflecting (TIR) surface for the OFF-state light.
Opening 136 provided in side wall 134 is designated for collecting the light beams from the light source and directing the collected light towards the spatial light modulator (108). Accordingly, opening 136 is optically aligned to the propagation path of the incident light from the light source, as illustrated in the figure.
Because the opening (136) is provided to collect the incident light and the opening is in the side wall 134 that is designated to bounce the recaptured off-state light, the opening has a preferred dimension such that off-state light leakage from the opening is minimized while collection of the incident light from the light source is maximized. The opening may have a dimension that matched to the dimension of the light incident thereto, such as the dimension of the illumination field of the light beam at the location of side wall 134. As an example, the width or height of the opening can be 1 mm or less, such as 0.5 mm or less, and 0.2 mm or less. The opening may have any desired shape, such as circle, rectangle, and square.
The other end (138) of optical integrator 132 is designated to capture the off-state light from the spatial light modulator (108). To maximize the capturing of the off-state light, side 138 of optical integrator 132 is substantially open; and the opened portion is optically aligned to the propagation path of the off-state light from the spatial light modulator. In particular, the opening portion of side 138 can be optically aligned to the illumination field of the off-state light at the location of side 138. Even though it is shown in the figure that side 138 and side 136 are substantially parallel and substantially have the same dimension, it is not required. In other examples, side 138 may have a shape and/or a dimension different from that of side 134, in which instance, optical integrator 132 can be tapered or extended from one end (e.g. side 134) to the other (e.g. side 138). Alternatively, optical integrator 132 can be assembled with another optical integrator or a suitable optical element (e.g. lens) such that capturing the off-state light from the spatial light modulator can be maximized.
Optical integrator 132 may have a solid body, such as a body filled with an optical material (e.g. glass) that is transmissive to the incident light. The optical integrator may alternatively comprise a hollowed body, such as an empty space surrounded by multiple reflective walls, one end-side wall 134, and the other end-side wall 138, as discussed above.
The incident light (106), including the light from the light source and the recycled light from the off-state light recycling mechanism, is then guided to the spatial light modulator by condensing lens 140 and prism assembly 142. For properly directing the incident light onto the pixels of the spatial light modulator (108) and spatially separating the ON-state and OFF-state light, the prism assembly employs TIR surface 146. Specifically, TIR surface 146 is optically disposed such that the incident light can be reflected to the spatial light modulator at a pre-determined direction; the off-state light (114) from the pixels at the OFF state can be directed towards side 138 of the off-state light recycling mechanism; and the ON-state light (109) from the spatial light modulator can travel through the TIR surface towards the projection lens (110). These can be achieved by aligning the TIR surface (146) such that the incident light and OFF-state light impinge the TIR surface at incident angles equal to or greater than the critical angle of the TIR surface; whereas the ON-state light impinges the TIR surface at an incident angle less than the critical angle of the TIR surface.
Condensing lens 140 is provided to form a proper illumination field on the TIR surface (146) such that the image of such illumination field projected on the spatial light modulator by the TIR surface has a proper optical profile. For example, the profile has an illumination area matching the pixel area of the spatial light modulator and/or the illumination intensity is substantially uniform across the pixel area. A proper optical profile can be achieved by adjusting the relative positions of condensing lens 140, TIR surface 146, and spatial light modulator 108.
In the example shown in
It is noted that
A Pulse-Width-Modulation Algorithm
For properly reproducing grayscale and color images, each pixel of the spatial light modulator (e.g. 108 in
At a particular time, bitplanes of the same group (having the same significance) can be displayed by the pixels of the spatial light modulator. Alternatively, bitplanes of the same group can be displayed at different time periods. In other words, the bitplanes being displayed by the pixels of all reset groups of the spatial light modulator at each time can be from the same group (of the same significance); or can be from different groups (of different significances).
Conversion of the pixels data (e.g. RGB data and YPbPr) of the incoming image or video signals into bitplane data can be performed in many ways, such as those set forth in U.S. Pat. No. 7,075,506 to Morgan, issued Jul. 11, 2006, U.S. Pat. No. 5,663,749 to Farris issued Sep. 2, 1997, and U.S. patent application Ser. No. 10/648,608 to Richards filed Aug. 25, 2003, the subject matter of each being incorporated herein by reference in its entirety. Such data conversion can be accomplished by a designated functional module, such as data processing unit 126, which can be a member of system controller 124 that is used to control operations of other functional members of the display system, as shown in
Because different bitplanes can cause different numbers of on-state and off-state pixels in the spatial light modulator, the amount of recycled off-state light varies over bitplanes for a given off-state light recycling mechanism. Such variation in turn causes unwanted illumination intensity changes on the screen in reproducing the desired image. As a consequence, the bitplanes derived from the desired image when displayed by the pixels of the spatial light modulator do not result in the desired image on the screen. This problem can be solved by many methods, one of which is by deriving the bitplanes from the desired image while including the illumination intensity variations due to recycled off-state light such that the derived bitplanes, when displayed by the pixels of the spatial light modulator in the presence of off-state light recycling, can yield the desired image on the screen. This bitplane derivation process can be performed by the data processing unit (126) as shown in
As an example,
Referring to
In equation 4, Ai is the average pixel level (the average value of the pixel data in linear light space) of the ith color image component during the frame period. Given the calculated gain for each color components, the frame gain gframe is determined (step 164) such that the frame gain gframe is equal to or less than the minimum gain of the color image components, which can be expressed as equation 5:
gframe≦Min(gi) (Eq. 5)
In one example, frame gain gframe is set to the minimum gain of the color image components. In other examples, the frame gain gframe is less than the minimum gain of the color image components by a predetermined value Δ that can be 20% or less, 10% or less, and 5% or less of the minimum gain of the color image components.
Referring again to
Referring to
Referring to
Referring again to
In equation 6, xi is the ratio of the number of ON-state pixels to the total number of pixels in the ith bitplane; timebitplane is the time allotted to the ith bitplane as discussed above with reference to step 153 in
Based on the calibrated pixel data curve and gain curve of MSB bitplane, the MSB bitplane is calculated according to the pixel data and an upper threshold. Specifically, the MSB bits of the image pixels (plotted in the X axis as shown in
Referring again to the flow chart in
Referring to
Referring to
Referring to
Referring to
Referring to
Referring to
Referring to
After calibrating all bitplanes (e.g. the above eight bitplanes as an example), the calibrated pixel data may have a residual value (energy) that are not represented by the combination of the previously calibrated bitplanes, as shown in curve 244
To present this residual energy (step 158 in the flow chart in
Referring to
Till this point, bitplanes including the calibrated bitplanes and the STM bitplanes have been obtained. These bitplanes are capable of representing both the intensity of the bitplanes derived from the desired image and the intensity of the recycled off-state light. Presenting these bitplanes in the pixels of the spatial light modulator of the display system can eliminate the intensity variation problem as discussed above.
The above discussed bitplane derivation is only one of many possible ways. In another example, bitplane thresholds values (or equivalently the input pixel code levels corresponding to the bitplane threshold values) for all bitplanes (e.g. from the MSB bitplane to the LSB bitplane) can be calculated using the above discussed method. The calculated thresholds are stored, for example in a column of a table with each threshold being in a cell of the column. Pixel data of all pixels of the image are then compared to the stored thresholds; and values of individual pixels in each bitplane are determined based on the comparison. Taking the MSB bitplane as an example, pixel data of the image are compared to the calculated threshold for the MSB bitplane. Pixels of the image having the pixel data values equal to or higher than the threshold for the MSB bitplane are identified through the comparison. The MSB bits of such identified pixels of the image are set to the ON-state value, such as “1;” and the MSB bits of other pixels (having image values lower than the threshold for the MSB) are set to the OFF-state value, such as “0.” Bit values of other pixel data can be determined in the same way using their corresponding thresholds. The adjusted pixel data can then be converted to corresponding bitplanes using many ways, such as those set forth in U.S. Pat. No. 7,075,506 to Morgan, issued Jul. 11, 2006, U.S. Pat. No. 5,663,749 to Farris issued Sep. 2, 1997, and U.S. patent application Ser. No. 10/648,608 to Richards filed Aug. 25, 2003, the subject matter of each being incorporated herein by reference in its entirety. It will be appreciated by those of skill in the art that the point at which image pixels are converted to bitplane pixels (whether immediately following each bitplane threshold calculation or after all bitplane threshold calculations are complete) has no effect on the function or spirit of the present invention. In an example, the upper threshold is the point at which the calibrated pixel data is equal to or higher than the bit-weight given by the gain curve (180). An example of such upper threshold is the crossing point (182) of calibrated pixel data curve 179 and gain curve 180. All pixels (i.e. pixels in region 184) having the calibrated pixel data equal to or above the upper-threshold are set to the ON-state.
In another example, a look up table (LUT) can be created and used for deriving individual bitplanes with an exemplary LUT being shown in TABLE 1. For demonstration purposes, table 1 assumes that the input image has 256 pixel levels and n bitplanes are to be derived for the image. Different pixel data levels for each color image component are in rows of the table 1; while the bits from MSB to LSB of the bitplanes are in columns of the table. The value in each cell indicates the ON (“1”) or OFF-state (“0”). This table can be generated through following steps.
After determining the thresholds for each bitplane (of each color image component) as discussed above with reference to
For a given pixel with a value from 0 to n, its corresponding bitplane bit values can be immediately determined from the LUT, as shown in TABLE 1. For example, assuming the red channel pixel value of the ith pixel in the incoming image is 3, then the red MSB bit for the ith pixel is 0; and the bits of the third red bitplane and the red LSB of the ith pixel are 1. In another example, assuming the red channel pixel value of the pth pixel in the incoming image is 255, then bits of all bitplanes from the red MSB to LSB are 1 according to the exemplary table 1. As such, bitplanes can be determined for all pixel values of the incoming image based on the LUT. It is noted that the above discussion, especially table 1, is for demonstration purpose only; and table 1 is only an example. The values of bitplanes in table 1 can be different for different images or image frames of video(s). The layout of the LUT, for example, the numbers of columns and rows and their arrangements in rows and columns, can be changed. For example, the data values can be plot in the columns; while the bits of the same bitplane can be plotted in rows. Input data values may or may not be plotted sequentially in ascending or descending orders; and can alternatively be in any orders, even randomly, so as the bits of the bitplanes in the table.
TABLE 1
Bitplane ON/OFF
Input Data
Residual
Values
MSB 1
2
3
. . .
. . .
LSB n
(float)
Red
0
0 (off)
0
0
0
0
0
1
0
0
0
0
1
0
2
0
0
1
0
1
0
3
0
0
1
0
1
1
. . .
0
1
1
0
1
1
. . .
. . .
. . .
. . .
. . .
. . .
. . .
255
1 (on)
1
1
1
1
1
Green
0
0
0
0
0
1
0
0
1
0
2
1
0
1
0
3
1
0
1
1
. . .
1
0
1
1
. . .
. . .
. . .
. . .
. . .
. . .
. . .
255
1
0
1
1
Blue
0
1
2
3
. . .
. . .
. . .
. . .
. . .
. . .
. . .
. . .
255
For demonstration purpose, a pseudo-code for deriving bitplanes based on the thresholds and a LUT is presented in appendix A.
In the above, derivation of the set of bitplanes from a specific color image component of the desired image and determination of a S™ bitplane have been accomplished. These processes can be repeated for all other image color components of the desired image.
As an example,
Another Pulse-Width-Modulation Algorithm
As discussed above, because different bitplanes (either having or not having the same significance) can cause different numbers of on-state and off-state pixels of the spatial light modulator, the amount of recycled off-state light varies over bitplanes for a given off-state light recycling mechanism. Such variation in turn causes unwanted illumination intensity changes on the screen in reproducing the desired image. As a consequence, the bitplanes derived from the desired image when displayed by the pixels of the spatial light modulator do not result in the desired image on the screen. This problem can alternatively be solved by displaying the bitplanes at different clock speeds depending upon the number of off-states (or on-states) in the bitplanes. Specifically, bitplanes having different numbers of off-state pixels therein are displayed at different clock speeds in the spatial light modulator such that bitplanes having different number of off-state pixels (resulting in different amounts of recycled off-state light) can be displayed for different time periods so as to compensate for the illumination intensity variations due to the off-state light recycling. This bitplane displaying algorithm can result in that bitplanes of different image frames in a video content composed of image frames may be displayed for different time periods, even for the bitplanes with the same significance.
As a way of example,
Referring to
After scaling, the sequence of color duty cycles is compressed, resulting in a residual time period in the frame time period as shown in
E=ε(ΣtiAi)+(1−ε) (Eq. 7)
In equation 7, ti is the proportion of the time allotted to each color image component of the desired image (or image frame). Specifically, t, is defined as Ti/Tframe, wherein Ti is the time allotted to the ith color image component (e.g. red color image component); and Tframe is the frame time. Accordingly, Σti=1. Ai is the average pixel value of the ith color image component in linear light space after de-gamma has been applied. Σ(tiAi) represents the average total number of on-state pixels in the image during the frame period Tframe.
In display applications, compression of the color duty sequence as illustrated in
As an example,
In general, a display system has at least one clock that generates clock signals based on which operations of the functional members including pixels of the spatial light modulator of the display system can be synchronized; or operations of a functional member of the display system can be triggered. Accordingly, durations of the bitplanes in the pixels of the spatial light modulator can be varied by changing the clock speed. As a way of example wherein a bitplane is to be displayed for 4 time units at the first clock speed according its weight (significance), such bitplane however can be actually displayed for 8 time units at the second clock speed that is half the first clock speed; and can be displayed for 2 time units at the third clock speed that is twice the first clock speed.
For displaying bitplanes at different clock speeds while within a frame period, a pulse-width-modulation (PWM) sequence is designed such that the sequence can run in a time period T of Tframe×Io/Imax, which is shorter than the frame time Tframe, such as 1/(60 HZ); wherein Io is the intensity defined in equation 1; and Imax is the maximum value of I as described in equation 1. In an example wherein the recycling efficiency ε is ⅔, Imax is 3Io; and the time period T for the PWM sequence can be 16667/3=5556 microseconds.
With the PWM sequence time that is shorter than the frame time, bitplanes can be displayed at different clock speeds without exceeding the frame time, wherein the clock speeds can be dynamically adjusted based on the number of off-state pixels in the bitplanes. As a way of example, the display time for each bitplane can be determined by equation 8 as expressed in the following:
In equation 8, C is the adjusted clock speed; Co is the clock speed provided by the display system to the spatial light modulator; noff is number of off-state pixels in the bitplane or bitplanes (when multiple bitplanes are displayed at a time) being displayed by the pixels of the spatial light modulator; Ntotal is the total number of pixels in the bitplane or bitplanes being displayed; ε is the recycling efficiency; and E is the time-stretch factor, which can be calculated by the above equation 7.
It can be observed from equation 8 that clock speed C is larger for bitplanes with more off-state pixels than for bitplanes with fewer number of off-state pixels. As a consequence, a first bitplane in one image frame may be displayed for a shorter time period than a second bitplane in another image frame when the first bitplane has more off-state pixels than the second bitplane even though the first and second bitplanes have the same weight (significance).
Calculating the clock speed and operating the spatial light modulator at the calculated clock speed can be accomplished in many ways, one of which is schematically illustrated in
Referring to
The pixels of the pixel array can be divided in many ways. For example, the pixels can be divided into groups with equal number of rows (or columns, or pixels or sub-blocks of pixels). As shown in the figure, assuming the pixels array has M rows, the pixel array can be equally divided into M/(i+1) groups with each group comprising (i+1) rows and i being 31 or any desired values. Pixels of each reset group are connected to one of a set of reset lines MBRST 0 to MBRST P. The reset lines are connected to reset driver 164, which can be a DAD reset driver by Texas Instrument, Inc.
Given the pixel reset groups, bitplanes are loaded to the corresponding reset groups of pixels for being displayed. The number of off-state pixels in each bitplane being displayed by the pixels of the spatial light modulator can then be calculated, as schematically illustrated in
In another example wherein a set of bitplanes is derived from the desired image with each bitplane being a collection of all pixel data bits of the same significance, calculation of the number of off-state pixels of a bitplane being displayed can also be performed using the counter table (180). Specifically, the counter table may be adapted such that each of columns 1 and 0 has one cell. After loading a bitplane to the entire array of pixels of the spatial light modulator, the cell in column 1 of the counter table (280) is incremented by 1 from its initial value for each off-state in the loaded bitplane. After the pixels of the spatial light modulator are reset based on the loaded bitplane, the value of the cell in column 1 can be shifted to the cell in column 0 followed by resetting the cell in column 1 to its initial value. The resulted value in the cell in column 0 is the total number of off-state pixels in the bitplane being displayed. Such obtained total number of off-state pixels is delivered to the clock speed calculator in
It is noted that the above described off-state pixel calculation method using a counter table is only one of many possible ways. Many other methods using different counter tables or even without using a counter table are also applicable.
Referring again to
As an example,
It is noted that calculation of the average pixel value is independent from other calculations until the calculation of the time-stretch factor E at step 288, and can alternatively be performed at any time prior to step 288 wherein the time-stretch factor E is calculated but after step 282 wherein pixel data are received. For example, the average pixel value can be performed before formatting the pixel data into bitplanes (step 284) and after receipt of the pixel data (step 282).
The method as discussed above with reference to the flow chart in
Referring to
Referring to
Similar to that discussed above with reference to
As an alternative feature, the brightness can be further improved by re-distributing energies among the colors of the sequence of color duty cycles while maintaining the color consistency of the image on the screen but with enhanced brightness. This arises from the fact that a mixture of primary colors (e.g. R, G, and B) can be represented by the corresponding secondary color (or white). For example, a mixture of the same amount of R, G, and B colors can be represented (replaced) by white color. A mixture of R and G colors can be represented (or replaced) by yellow color. Therefore, an energy distribution of an image pixel over a color duty cycle having secondary colors and white can be equivalently represented by another energy distribution over the same color duty cycle sequence. For enhancing the brightness of the displayed image, energy distribution can be performed in favor of the energy in the white and secondary colors, as will be discussed in the following with reference to
Referring to
W1=W0+Min(R0,G0,B0)
R1=R0−Min(R0,G0,B0)
G1=G0−Min(R0,G0,B0)
B1=B0−Min(R0,G0,B0) (Eq. 9)
In equation 9, W1 and W0 are the pixel values of the white color after and before the energy transfer. Min(R0,G0,B0) is the minimum value of the R, G, and B pixel values before the energy transfer. R1 and R0 are the pixel values of the red color after and before the energy transfer. G1 and G0 are the pixel values of the green color after and before the energy transfer; and B1 and B0 are the pixel values of the blue color after and before the energy transfer.
After the above energy transfer, another same amount of red and green colors can be transferred to the yellow color, which can be expressed as equation 10.
R2=R1−Min(R1,G1)
G2=G1−Min(R1,G1)
Y1=Y0+Min(R1,G1) (Eq. 10)
In equation 10, Min(R1,G1) is the minimum value of the R1 and G1 pixel values. R2 and R1 are the pixel values of the red color after and before the energy transfer to yellow. G2 and G1 are the pixel values of the green color after and before the energy transfer to yellow; and Y1 and Y0 are the pixel values of the yellow color after and before the energy transfer.
The energy distribution after the above energy transfers is schematically illustrated in
The above energy re-distribution is performed for all image pixels. If possible, two additional energy transfers are performed that are similar to that of equation 10, but for cyan and magenta. Specifically, after any possible yellow transfer has been performed, the minimum of the resulting green and blue pixel value is transferred to cyan. Subsequently, the minimum of the resulting red and blue pixel value is transferred to magenta. Based on the image after the energy re-distribution, bitplanes are derived for image components with colors in the color duty cycle sequence. Off-state recycling gains are calculated from the off-state recycling of the image components with colors in the color duty sequence. The calculated gains are used to determine the scaling factors for scaling the sequence of color duty cycles and pulse-width-modulation sequence as discussed above with reference to
In re-distributing energies among the colors of the sequence of color duty cycles, the energy re-distribution may be subject to constraints to maintain proper image presentations. For example, the amount of energy moved into a particular color duty cycle is desired to be equal to or less than the maximum pixel value allowed by the particular color duty cycle such that the total energy of the particular color duty cycle (including the moved amount) can be achieved by displaying the corresponding bitplanes. This arises from that the fact that, when the time period of a particular color duty cycle, such as the white color duty cycle, is very small the total amount of energy (including the moved energy from the R, G, B colors) may not be properly achieved by displaying the corresponding bitplanes during the short duty cycle time period. As a consequence, the amount of energy to be moved to the particular color, such as white is desired to be determined by the maximum value allowed by the time period of the specific color duty cycle. In general, it is preferred, though not required, that the energy re-distribution preferably starts from moving energies into the white color duty cycle; and move as much energy from the primary colors (e.g. R, G, and B) into the white color duty cycle; and then performing energy redistribution towards other secondary colors. Alternatively, energy redistribution can be performed from moving energies into one or more secondary colors, then moving energies into the white color duty cycle.
In addition to the above constraint, other constraints may apply, which are listed as follows. In the following inequalities, r, g, and b represent the input pixel's RGB values, normalized to a value in the range from 0 to 1; and R, G, B, C, M, Y, and W represent the duty cycle of each color illuminant such that the sum of R, G, B, C, M, Y, and W is 1.
g <= G + C + Y + W;
r <= R + M + Y + W;
b <= B + M + C + W;
g − r <= G + C;
r − g <= R + M;
r − b <= R + Y;
b − r <= B + C;
g − b <= G + Y;
b − g <= B + M;
r − g − b <= R;
b − r − g <= B;
g − r − b <= G;
g + b − r <= G + 2C + B + W;
g + r − b <= G + R + 2Y + W;
r + b − g <= R + B + 2M + W;
r >= 0:
g >= 0; and b >= 0.
In performing the energy re-distribution, each of the above constraints can be checked to ensure that no constraints are violated. If a violation occurs in moving an amount of energies, the amount of energies to be moved is desired to be adjusted to remove the violation. It is noted that the above discussion with reference to
It will be appreciated by those of skill in the art that a new and useful off-state light recycling mechanism and a pulse-width-modulation technique for use in display systems employing an off-state recycling mechanism have been described herein. In view of the many possible embodiments, however, it should be recognized that the embodiments described herein with respect to the drawing figures are meant to be illustrative only and should not be taken as limiting the scope of what is claimed. Those of skill in the art will recognize that the illustrated embodiments can be modified in arrangement and detail. Therefore, the devices and methods as described herein contemplate all such embodiments as may come within the scope of the following claims and equivalents thereof.
APPENDIX A
Pseudo-code of an exemplary process for deriving bitplanes
START
ε = recycling efficiency
for each frame
for each color
Calculate Average Picture Level for each color in linear space
APL(color) = sum(degamma(pixels(color))) / total number of pixels
Find the recycling gain for this color channel
gain(color) = 1 / (1−ε*(1−APL(color)))
end (for each color)
Find the gain for this frame (the minimum gain of the three color channels)
gainframe = min(gain)
for each color
Initialize LEVEL-COUNT TABLE by creating a histogram of the input levels
(0..255) along with the linear light level after the frame gain has been applied:
Input
Pixel
Level
Gained Linear Level
Count
0
= gainframe
# pixels at
*degamma(input level 0)
code 0
1
= gainframe
# pixels at
*degamma(input level 1)
code 1
. . .
. . .
. . .
255
= gainframe
# pixels at
*degamma(input level
code 255
255)
Initialize the time remaining in the frame
time_remaining = 1
for each bitplane from MSB to LSB
Calculate the duration of this bitplane (out of a total time of 1)
bit_time = time_remaining*(1/(2-log(1− ε)))
time_remaining = time_remaining − bit_time
for each input level transition from 0→1 to 254→255 (could be
replaced by a smart search algorithm, such as a binary search,
to find first level above gainbitplane)
Determine fraction of pixels below this level transition
fraction_below = cumulative_sum(pixel_count(0 to level)) /
total number of pixels
Determine recycling gain for this bitplane if this fraction of
pixels are off
gainbitplane = bit_time*(1./(1−(ε*fraction_below)))
if (Gained Linear Level for input level > gainbitplane)
All pixels with Gained Linear Level at or above this
upper level threshold will be ON for this bitplane
Assign ON (1) for all levels of this color above current
level for this bitplane into ENUMERATION
TABLE:
Input
Bitplane ON/OFF
Data
MSB
Residual
Values
1
2
3
. . .
. . .
LSB n
(float)
Red
0
0
0
0
0
0
0
(off)
1
0
0
0
0
1
0
2
0
0
1
0
1
0
3
0
0
1
0
1
1
. . .
0
1
1
0
1
1
. . .
. . .
. . .
. . .
. . .
. . .
. . .
255
1
1
1
1
1
1
(on)
Green
0
0
0
0
0
1
0
0
1
0
2
1
0
1
0
3
1
0
1
1
. . .
1
0
1
1
. . .
. . .
. . .
. . .
. . .
. . .
. . .
255
1
0
1
1
Blue
0
1
2
3
. . .
. . .
. . .
. . .
. . .
. . .
. . .
. . .
255
Update the LEVEL-COUNT TABLE by subtracting the
amount of light displayed during this bitplane
from the Gained Linear Level for each input
level:
Input
Pixel
Level
Gained Linear Level
Count
0
= previous − gainbitplane (if
# pixels at
bitplane ON at this level)
code 0
= previous (if bitplane
OFF)
1
= previous − gainbitplane (if
# pixels at
bitplane ON at this level)
code 1
= previous (if bitplane
OFF)
. . .
. . .
. . .
255
= previous − gainbitplane (if
# pixels at
bitplane ON at this level)
code 255
= previous (if bitplane
OFF)
Sort the LEVEL-COUNT TABLE in ascending order
based on Gained Linear Level, keeping each row
intact.
BREAK from for each level transition loop
else
Assign OFF (0) for this level of this color for this
bitplane in ENUMERATION TABLE.
end if (Gained Linear Level for input level > gainbitplane)
end (for each input level transition)
end (for each bitplane)
Use STM dithering to achieve the residual intensities:
The values remaining in the LEVEL-COUNT TABLE after the LSB level has
been calculated represent the intensities to be represented via STM.
Bitplane ON/OFF
Input Data
MSB
Values
1
2
3
. . .
. . .
LSB n
Residual (float)
Red
0
0
0
0
0
0
0
= Gained Linear Level
(off)
from LEVEL-COUNT
TABLE after LSB
1
0
0
0
0
1
0
. . .
2
0
0
1
0
1
0
. . .
. . .
. . .
. . .
. . .
. . .
. . .
. . .
. . .
Calculate the light intensity of the STM bitplane by determining, on average,
how many pixels will be ON. This is a function of the mean of the
residual values.
APLresidual = sum(Gained Linear Levels * pixel count) / total number of pixels
fraction_OFFSTM = (APLresidual − time_remaining) / (APLresidual * ε −
time_remaining)
IntensitySTM = time_remaining * (1 / (1− ε*fraction_OFFSTM))
Scale the residual values by this STM light intensity to get a number between 0
and 1 that STM can use for thresholding.
for each Input Data Level
Residual = Residual / IntensitySTM
end (for each Input Data Level)
end (for each color)
With the ENUMERATION TABLE completely filled in (including the scaled residual
values), calculate bitplanes and perform STM as normal.
end (for each frame)
Russell, Andrew Ian, Lieb, David Foster, Ramanath, Rajeev
Patent | Priority | Assignee | Title |
Patent | Priority | Assignee | Title |
5663749, | Mar 21 1995 | Texas Instruments Incorporated | Single-buffer data formatter for spatial light modulator |
5765934, | Aug 04 1995 | Mitsubishi Denki Kabushiki Kaisha | Projection type display |
6201521, | Sep 27 1996 | Texas Instruments Incorporated | Divided reset for addressing spatial light modulator |
6648475, | May 20 2002 | IMAX Theatres International Limited | Method and apparatus for increasing color gamut of a display |
6939009, | Feb 06 2001 | Optics 1, Inc.; Optics 1, Inc | Compact work light with high illumination uniformity |
6980197, | Oct 30 2003 | Texas Instruments Incorporated | Integrated driver for use in display systems having micromirrors |
7075506, | Feb 25 2000 | Texas Instruments Incorporated | Spatial-temporal multiplexing |
7113324, | Feb 12 2004 | Benq Corporation | Image display apparatus |
7213929, | Oct 21 2002 | Olympus Corporation | Illumination apparatus and image projection apparatus |
7417782, | Feb 23 2005 | SNAPTRACK, INC | Methods and apparatus for spatial light modulation |
7826121, | Sep 15 2008 | Texas Instruments Incorporated; Texas Instruments Inc | Use of an angle-selective retro-reflector to recapture off-state energy |
7876340, | Apr 03 2007 | Texas Instruments Incorporated | Pulse width modulation algorithm |
20070053074, | |||
20080246706, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
Apr 18 2011 | Texas Instruments Incorporated | (assignment on the face of the patent) | / |
Date | Maintenance Fee Events |
Jul 25 2016 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Jul 23 2020 | M1552: Payment of Maintenance Fee, 8th Year, Large Entity. |
Jul 24 2024 | M1553: Payment of Maintenance Fee, 12th Year, Large Entity. |
Date | Maintenance Schedule |
Feb 19 2016 | 4 years fee payment window open |
Aug 19 2016 | 6 months grace period start (w surcharge) |
Feb 19 2017 | patent expiry (for year 4) |
Feb 19 2019 | 2 years to revive unintentionally abandoned end. (for year 4) |
Feb 19 2020 | 8 years fee payment window open |
Aug 19 2020 | 6 months grace period start (w surcharge) |
Feb 19 2021 | patent expiry (for year 8) |
Feb 19 2023 | 2 years to revive unintentionally abandoned end. (for year 8) |
Feb 19 2024 | 12 years fee payment window open |
Aug 19 2024 | 6 months grace period start (w surcharge) |
Feb 19 2025 | patent expiry (for year 12) |
Feb 19 2027 | 2 years to revive unintentionally abandoned end. (for year 12) |