Liquid crystal display (LCD) panels frequently are used in near-eye display systems, such as virtual reality (VR) or augmented reality (AR) head-mounted display (HMD) devices. However, the time needed to address every row in the LCD panel, coupled with the relatively long settling time of the liquid crystals implemented in the LCD panel (that is, the “LC settling time” or “LC settling period”), can limit the maximum frame rate implemented in a conventional LCD panel. Moreover, many near-eye display systems utilize a single LCD panel for both eyes, which can lead to problems with motion blur, especially at higher refresh rates. Conventional approaches to reducing motion blur typically incorporate specialized backlighting in order to illuminate the LCD panel with low persistence. However, given the frame rate limitations of conventional LCD panel driving techniques, the impact of specialized backlighting on reducing motion blur is limited.
The present disclosure may be better understood, and its numerous features and advantages made apparent to those skilled in the art by referencing the accompanying drawings. The use of the same reference symbols in different drawings indicates similar or identical items.
Head-mounted display (HMD) devices and other near-eye displays often utilize LCD panels due to their ubiquity and relative low cost. However, the frame period (which is inversely proportional to the frame rate) in a conventionally-timed LCD panel is relatively long due to the need to wait for the liquid crystals of the LCD panel to settle to their new states reflective of the input pixel data for a new display image before activating the backlighting used to display the display image. As such, conventionally-timed LCD panels often act as a bottleneck for virtual reality (VR) and augmented reality (AR) applications, which typically require high frame rates in order to provide acceptable experiences to users.
As described below, a timing scheme in which backlighting is activated before liquid crystal settling has completed for all of the pixel rows of the LCD panel can introduce “corruption” in the last one or more pixel rows of the LCD panel as the liquid crystals of those pixel rows may not be in the appropriate states for the corresponding pixel values. Similarly, initiating addressing of the first one or more rows of pixels of the next display image before the backlight has been activated for the previous display image can introduce “corruption” in the first one or more pixel rows of the LCD panel as these pixel rows contain pixel data for the next display image while the remaining pixel rows contain pixel data from the previous display image, and thus the liquid crystals for these first one or more pixel rows may be in an indeterminate state when the backlight is activated for display of the previous display image. However, when implemented in an HMD device or other near-eye display system, the LCD panel typically is arranged in a “landscape” orientation such that the top and bottom pixel rows of the LCD panel become the most peripheral pixel “columns” of the display relative to the user's perspective (that is, the user perceives the “top” and “bottom” of the LCD panel as the lateral edges of the display). Thus, the pixel corruption introduced by the overlapping addressing/backlighting timing techniques described herein appear at the lateral edges of the field of view (FOV) of the user where the user is less sensitive to visual aberrations. As such, the overlapping addressing/backlighting timing techniques described herein facilitate increased frame rates in LCD panel implementations, with the commensurate reduction in motion blur, at the cost of slight pixel corruption at the periphery of the user's FOV that typically will go unnoticed by the user. Moreover, such pixel corruption can be mitigated by configuring the optics of the near-eye display device to occlude or defocus the peripheral pixels, and thus preventing the pixel corruption from being observable by the user.
Turning now to
The HMD device 100 comprises a housing 102 having a surface 104, and a face gasket 106 and set of straps or a harness (omitted from
The display panel 108 includes a two-dimensional array 206 of liquid crystal-based pixels 208, a row controller 214, a display driver 216, a backlight 218 underlying the array 206 (although depicted to the side for ease of illustration), a backlight controller 220, and a timing controller 222. The controllers 210, 214, 216, 220, and 222 each may be implemented as hard-coded logic (e.g., an application specific integrated circuit (ASIC), programmable logic (e.g., a field programmable gate array (FPGA), or a combination thereof. The interconnect 203 may include any of a variety of interconnects utilized to connect a display panel to a corresponding device or other display sub-system, such as an interconnect based on one or more interconnects standards, such as an inter-integrated circuit (I2C)-based standard, a DisplayPort™-based standard, a high-definition multimedia interface (HDMI)-based standard, one or more proprietary interconnect configurations, or a combination thereof.
As well known in the art, each pixel 208 of the array 206 represents a corresponding color component of a corresponding pixel of the LCD panel 108 and includes a liquid crystal layer disposed between one or more polarizing layers and one or more color filter layers, as wells as circuitry to selectively generate an electric field to align the liquid crystals responsive to a pixel value buffered for the pixel 208. In some embodiments, the array 206 and the pixels 208 are configured in accordance with an In-Plane Switching (IPS) configuration, whereas in other embodiments the array 206 and the pixels 208 contained therein are configured in accordance with another LCD technology, such as a twisted nematic field effect (TN) configuration.
As a general operational overview, the display system 200 operates to generate and display a sequence of display images to a user. To this end, the memory 207 stores a software application 234 that, when executed by the processor 205 or other processor of the rendering device 202, manipulates the processor 205 to generate a sequence of display images that together represent a video sequence. This sequence of display images may comprise completely computer-rendered imagery, such as video generated to represent a user's viewpoint into a VR scene (that is, VR content), entirely captured imagery, or a combination of captured imagery and computer-rendered imagery, such as found in augmented-reality (AR) content. Each generated display image is provided to the display controller 210 in sequence, and the display controller 210 in turn transmits the pixel data of the display image in sequence to the LCD panel 108 via the interconnect 103 on a row-by-row basis.
As each row of pixel data is received at the LCD panel 108, the row is temporarily buffered in the display driver 216. The display driver 216 and row controller 214 operate together to write the pixel data buffered in the display driver 216 to the corresponding buffering elements of the pixels 208 of the corresponding row of the array 206. This process of buffering pixel data representing a display image into the corresponding buffering elements of the pixels 208 of the array 206 on a pixel row-by-row basis is referred to herein as “addressing” the pixel data of a display image. With the pixel values so stored, the circuitry of each pixel 208 of the corresponding row selectively generates an electric field responsive to the pixel value buffered for the pixel 208, and if an electric field is generated for the pixel 208, the electric field manipulates the orientation of the liquid crystals for the pixel 208 so as to selectively permit light from the backlight 218 to pass or to be blocked when the backlight 218 is activated.
The re-orientation, or “settling”, of the liquid crystals of the pixel 208 in response to generation of an electric field takes a certain period of time, typically referred to as the liquid crystal's “settling time.” Until the liquid crystals have been given sufficient time to settle, the liquid crystals are in an indeterminate state and thus may either permit transmission of light or block transmission of light in a manner inconsistent with the intended effect reflected by the stored pixel value. Accordingly, to ensure that the liquid crystals of all pixel rows of an LCD panel are settled before triggering the backlight 218, conventional LCD panel timing schemes require that the triggering of the backlight be delayed until at least a set duration after the last pixel row has been addressed with the corresponding row of pixel data for the image to be displayed, with this set duration being representative of the expected settling time of the liquid crystals of the LCD panel.
Referring briefly to
Thus, while effective at avoiding pixel corruption at the top and bottom rows of the LCD panel, the conventional approach of delaying the backlight activation until all rows are settled results in a longer frame period, and thus a lower frame rate. However, as an LCD panel implemented in a near-eye display system, such as the HMD 100, typically is arranged in a landscape mode and is positioned close to the user's eyes, the top and bottom rows of the LCD panel are located at the lateral periphery of the user's FOV, and thus any corruption of the pixels in these rows is less likely to be detected, and thus less likely impact the user's experience. Accordingly, in at least one embodiment, the timing controller 222 of the LCD panel 108 leverages the relatively low impact of top and bottom pixel row corruption on user viewing experience in a near-eye implementation to implement a timing scheme for the display driver 216, the row controller 214, and the backlight 218 in coordination with the display controller 210, so as to overlap one or both of the backlight activation period and the addressing of the next display image with the settling period of the last one or more rows of the array 206 so as to reduce the frame period, and thus increase the frame rate.
If the display image is the first display image to be generated (i.e., this iteration is the first iteration of method 400), the process of block 404 is skipped. Otherwise, at block 404 the timing controller 214 coordinates with the display controller 210 to delay addressing of the current display image (that is, the transmission to, and buffering of, of pixel data for the generated display image at the array 206 of pixels 208) until a specified duration has passed since addressing for the previous display image has completed. This specified duration represents the time needed for the liquid crystals of the last pixel row to settle for the previous display image. To illustrate, assuming the liquid crystal settling time is 4.1 milliseconds (ms), then the timing controller 214 would wait until at least 4.1 ms after the last pixel row was addressed for the previous display image before signaling the display controller 210 to initiate addressing of the next display image.
After the LC settling period from addressing the previous display image has completed, at block 406 the timing controller 222 signals the display controller 210 to begin transferring pixel data for the display image generated at block 402 on a row-by-row basis to the LCD panel 108 via the interconnect 203. As each row of pixel data comes in, the pixel data is received at the display driver 216 and then the pixel value for each column is transmitted to and buffered at the corresponding row of pixels 208 as directed by signaling for the row by the row controller 214. At block 408, the timing controller 222 determines whether the most recent row addressed was the last row of the current display image. If not, the process at block 406 of addressing a row of pixel data is repeated for the next row of pixel data. Otherwise, if at block 408 the timing controller 222 determines the most recent row addressed was the last row of the current display image, flow returns to block 402 for the next iteration of method 400 for the next display image to be generated, addressed, and displayed. Further, with the addressing of the last row, the timing scheme has entered the tail end of the settling period for liquid crystals of the array 206. Accordingly, at block 410 the timing controller 222 signals the backlight controller 220 to initiate activation of the backlight 218 during the liquid crystal (LC) settling period of the last one or more pixel rows of the array 206. That is, the backlight 218 is activated even though one or more of the last pixel rows of the array 206 are still unsettled. Doing so will likely result in corruption in display of the image content contained in these one or more last pixel rows, but as noted above this corruption will occur at the periphery of the user's FOV, and comes with the benefit of reducing the frame period for displaying the display image.
To illustrate,
The delay between end of addressing of the last pixel row at time t2 and the activation of the backlight 218 at time t3 may be determined based on a number of factors, including the LC settling time, the intended backlight activation duration, and the like. To illustrate, the fewest rows of the array 206 will be corrupted by the early activation of the backlight 218 by shifting the backlight activation so that the backlight activation terminates at the very end of the LC settling period. To illustrate, with an LC settling time of, for example, 4.0 ms and a specified backlight activation duration of 1.1 ms, the timing of activation of the backlight 218 can be specified to be 2.9 ms after the end of addressing of the last pixel row (that is, t3=t2+2.9 ms)
During the addressing and backlight activation periods for the first display frame, the rendering device 202 renders a second display image (image 2). At time t5 following the end of the LC settling period (t5>=t4), the timing controller 222 signals the display controller 210 to begin transmission of the pixel data for the second display image, and thus addressing (block 504) of the second display image is initiated at time t5, and the same overlapping addressing/backlighting timing scheme is employed for the second display image, and the following display image, and so on.
As illustrated by this example, the frame period 506 of a display image is represented by the time between initiation of addressing of the first pixel row of the display image at time t0 and initiation of addressing of the first pixel row of the next display image at time t5 (which is effectively time 4 for purposes of calculating frame period). Thus, assuming, for example, an 8.3 ms addressing period (i.e., t2−t0=8.3 ms) and a 4 ms LC settling period (i.e., t4−t3=4 ms), the frame period is 12.3 ms, which represents a maximum frame rate of approximately 81.3 frames per second (fps). Using these same values and a 1.1 ms backlight activation period, the frame period of a conventional timing scheme is a minimum of 13.4 ms, and thus having a maximum frame rate of only 74 fps. This increase in frame rate comes at the expense of potential corruption in the display of the pixels at the last pixel rows of the LCD panel 108. However, this corruption may be imperceptible, or nearly so, to the user as the corrupted pixel rows are at the lateral periphery of the user's FOV, and thus represents a more than fair tradeoff for the improved frame rate and reduced motion blur that may be achieved as a result.
Assuming the display image generated at block 602 is not the first display image generated in the corresponding sequence of display images (that is, this is a second or subsequent iteration of method 600), at block 604 the timing controller 222 signals the display controller 210 to initiate addressing of the display image generated at block 602 to the array 206 of the LCD panel 108 during the LC settling period of the previous display image addressed to the array 206. That is, rather than waiting for the LC settling period to end for one display image before starting the addressing of the next display image as in method 400, method 600 takes a more aggressive approach of initiating addressing of the next display image while the last one or more pixel rows are still settling for the previous display image.
At block 606, the timing controller 222 determines whether the last row of the display image generated at block 602 has been addressed to the last pixel row of the array 206. If not, the method flow returns to block 604 for the next row of pixel data. Otherwise, if the last pixel row has been addressed, flow returns to block 602 for the next iteration of method 600 for the next display image to be generated, addressed, and displayed. Further, with the addressing of the last row, the timing scheme has entered the tail end of the settling period for liquid crystals of the array 206. Accordingly, at block 608 the timing controller 222 signals the backlight controller 220 to initiate activation of the backlight 218 during the liquid crystal (LC) settling period of the last one or more pixel rows of the array 206.
At time t1, the timing controller 222 signals the display controller 210 to initiate addressing of a first display image (image 1) by transmitting pixel data for the first display image on a sequential row-by-row basis, such that the first (top) row (row 0) is addressed at time t1 and the last (bottom) row (row N-1) is addressed at time t4, as represented by block 702. The resulting LC settling period (represented by block 703) initiates at time t3 (t3>t1) for row 0 and terminates for row N-1 at time t7 (t7>t3). The period between the end of addressing for the first display image at time t4 and the end of the LC settling time of the last pixel row N-1 at time 74 represents a window for both the activation and subsequent deactivation of the backlight 218 to generate a backlight pulse for displaying the first display image and for the initiating of addressing for the next display image. Accordingly, at time t5 (t4<t5<t7), the timing controller 222 signals for activation of the backlight 218, and at some time thereafter and before or at time t7, the controller 222 signals for deactivation of the backlight 218. In the illustrated example, the backlight 218 is terminated at the same time as the end of the expected LC settling period at time t7, but in other embodiments the backlight 218 may be deactivated sooner.
Further, the timing controller 222 signals the display controller 210 to initiate addressing (block 705) of a second display image (image 2) at a time t6 after the end of addressing of the first display image and prior to the end of the LC settling period (t4<t6<t7). As such, the timing of the backlight activation/deactivation period (block 704) “overlaps” the LC settling period (block 703) for one or more of the last pixel rows of the array 206. The limiting of the initial portion of the addressing of the next display image (block 705) likewise overlaps the LC settling period. As such, both the backlight activation period and the addressing of the next display image effectively overlaps the end of the addressing period for the first display image. This results in a shortened frame period for each display image compared to both the conventional LCD timing scheme and the overlapping timing scheme of method 400. To illustrate, the frame period 706 of a display frame in accordance with the overlapping timing scheme illustrated by
Initiation of addressing of the next display image before the LC settling period for the previous display image completes for the previous display image results in the array 206 containing pixel data for the next display image in the first one or more pixel rows and pixel data for the previous display image in the remaining pixels, the last one or more of which are still waiting for LC settling. Accordingly, the first pixel rows and last pixel rows have an indeterminate state, and thus are “corrupted,” during the corresponding activation of the backlight 218 during this period. However, as noted above, the first and last pixel rows of the LCD panel 108 are at the lateral periphery of the user's FOV and thus less likely to be noticed by the user. Moreover, any such edge corruption typically would be a fair trade for the increased frame rate provided by allowing the edge corruption. Also, it will be appreciated that in the timing scheme of method 600, the edge corruption is balanced between both lateral edges, rather than being concentrated at the lateral edge corresponding to the bottom rows of the array 206, and thus is likely to be less discernible than the pixel corruption triggered by the timing scheme represented by method 400. In the event that the pixel corruption is at risk of distracting the user, in some embodiments, the lenses 112, 114 (
In some embodiments, certain aspects of the techniques described above may implemented by one or more processors of a processing system executing software. The software comprises one or more sets of executable instructions stored or otherwise tangibly embodied on a non-transitory computer readable storage medium. The software can include the instructions and certain data that, when executed by the one or more processors, manipulate the one or more processors to perform one or more aspects of the techniques described above. The non-transitory computer readable storage medium can include, for example, a magnetic or optical disk storage device, solid state storage devices such as Flash memory, a cache, random access memory (RAM) or other non-volatile memory device or devices, and the like. The executable instructions stored on the non-transitory computer readable storage medium may be in source code, assembly language code, object code, or other instruction format that is interpreted or otherwise executable by one or more processors.
A computer readable storage medium may include any storage medium, or combination of storage media, accessible by a computer system during use to provide instructions and/or data to the computer system. Such storage media can include, but is not limited to, optical media (e.g., compact disc (CD), digital versatile disc (DVD), Blu-Ray disc), magnetic media (e.g., floppy disc, magnetic tape, or magnetic hard drive), volatile memory (e.g., random access memory (RAM) or cache), non-volatile memory (e.g., read-only memory (ROM) or Flash memory), or microelectromechanical systems (MEMS)-based storage media. The computer readable storage medium may be embedded in the computing system (e.g., system RAM or ROM), fixedly attached to the computing system (e.g., a magnetic hard drive), removably attached to the computing system (e.g., an optical disc or Universal Serial Bus (USB)-based Flash memory), or coupled to the computer system via a wired or wireless network (e.g., network accessible storage (NAS)).
Note that not all of the activities or elements described above in the general description are required, that a portion of a specific activity or device may not be required, and that one or more further activities may be performed, or elements included, in addition to those described. Still further, the order in which activities are listed are not necessarily the order in which they are performed. Also, the concepts have been described with reference to specific embodiments. However, one of ordinary skill in the art appreciates that various modifications and changes can be made without departing from the scope of the present disclosure as set forth in the claims below. Accordingly, the specification and figures are to be regarded in an illustrative rather than a restrictive sense, and all such modifications are intended to be included within the scope of the present disclosure.
Benefits, other advantages, and solutions to problems have been described above with regard to specific embodiments. However, the benefits, advantages, solutions to problems, and any feature(s) that may cause any benefit, advantage, or solution to occur or become more pronounced are not to be construed as a critical, required, or essential feature of any or all the claims. Moreover, the particular embodiments disclosed above are illustrative only, as the disclosed subject matter may be modified and practiced in different but equivalent manners apparent to those skilled in the art having the benefit of the teachings herein. No limitations are intended to the details of construction or design herein shown, other than as described in the claims below. It is therefore evident that the particular embodiments disclosed above may be altered or modified and all such variations are considered within the scope of the disclosed subject matter. Accordingly, the protection sought herein is as set forth in the claims below.
Number | Name | Date | Kind |
---|---|---|---|
8482698 | Atkins | Jul 2013 | B2 |
8773336 | Knapp | Jul 2014 | B2 |
8994640 | Slavenburg et al. | Mar 2015 | B2 |
10209523 | Zhang | Feb 2019 | B1 |
20070132709 | Kawaguchi | Jun 2007 | A1 |
20160307482 | Huang | Oct 2016 | A1 |
20170287408 | Shi et al. | Oct 2017 | A1 |
20170308161 | Richards | Oct 2017 | A1 |
20170309245 | Richards | Oct 2017 | A1 |
20180090078 | Chang | Mar 2018 | A1 |
20180197482 | Choi | Jul 2018 | A1 |
20200005717 | Masuda | Jan 2020 | A1 |
Number | Date | Country |
---|---|---|
2109094 | Oct 2000 | EP |
Entry |
---|
International Search Report and Written Opinion dated May 21, 2019 for corresponding International Application No. PCT/US2019/023116, 13 pages. |
“Motion Blur Reduction (ULMB, LightBoost, etc.)” <https://www.blurbusters.com/faq/motion-blur-reduction/> Accessed Apr. 24, 2018, 10 pages. |
International Preliminary Report on Patentability dated Oct. 29, 2020 for International Application No. PCT/US2019/023116, 8 pages. |
Number | Date | Country | |
---|---|---|---|
20190318701 A1 | Oct 2019 | US |