The present invention is directed to integrated circuits and, more particularly, to a controller for a persistent display panel.
Persistent display panels are widely used in e-readers, for example. An e-reader is a portable battery-powered electronic device that is particularly adapted to reading text, with or without pictures. An e-reader has good readability in bright ambient light, even sunlight. The power consumption is very low, giving long battery life between recharging. Some e-readers have a battery life of one to two months before recharging.
For displaying video or games, for example, the frame displayed is refreshed continuously at a rate of 50 Hz to 200 Hz or more to display motion pictures. In an e-reader, however, the image of the page displayed is static and does not change while the page is read. Updating continuously the page to be displayed in an e-reader at such a fast frame refresh repetition rate is unnecessary. A persistent display panel is not well suited to displaying motion pictures but is well adapted to displaying the static image of a page in an e-reader. Persistent display panels have low power consumption while the image is unchanged, which is an important advantage in an e-reader.
A commonly used technology for a persistent display panel is e-paper, which electronically generates an image comparable to a traditional printed ink paper. The image reflects ambient light giving high contrast and a wide reading angle. An example of e-paper technology is an electrophoretic display (EPD), which can hold an unchanging image of text or a picture almost indefinitely with negligible power consumption. An EPD panel has pigmented particles in suspension, usually in micro-capsules between two plates bearing arrays of electrodes. Voltages applied to the electrodes produce electrical fields of pixel size that re-arrange the pigmented particles to update the displayed image.
The image on a persistent display panel can persist for long periods, hours or even days, in the absence of electric fields. However, building up the display of a new image can be slow, and a ghost of the previous image may persist after the frame is updated. A common technique for reducing these concerns is to apply voltages many times during the frame refresh, that is to say the image update.
The successive voltages (waveforms) applied to any given pixel during the frame refresh are a function of the previous state of the pixel, its current transitional state, and its intended new state. Commonly, the waveforms are functions of the temperature of the EPD, which is sensed and serves as a parameter in deriving the waveforms. The waveforms may also be different for different modes of frame refresh, for example initialization, in which any image persisting on the panel is cleared, monochrome, which displays a black-and-white image, gray-scale mode, which is commonly used, and full color mode, which is not widely used yet.
Increasing resolution and screen size of e-reader panels increase the amount of data to process in producing the frame refresh waveforms. Typically, a central processor unit (CPU) extracts pixel data for the image content from memory and loads the relevant pixel data into pixel buffers. A conventional approach uses a dedicated hardware controller that receives the pixel data from the pixel buffers and provides waveform data to drivers that generate the waveforms for the display panel. However, since the hardware controller is specific to the e-reader that it is used with, incompatible applications cannot use it, making a dedicated hardware controller a costly solution.
It is possible to convert pixel data to waveform data using software. However, the quantity of data to be processed, especially for high resolution and large screen sizes makes the frame refresh too slow.
Thus, it would be advantageous to have a controller for a persistent display panel that is less inflexible than a hardware controller, while offering high speed frame refresh.
The present invention, together with objects and advantages thereof, may best be understood by reference to the following description of embodiments thereof shown in the accompanying drawings. Elements in the drawings are illustrated for simplicity and clarity and have not necessarily been drawn to scale.
The CPU 112 has a single-instruction, multiple-data (SIMD) module 126 that can be used as a media processing engine for instructions for different requirements, such as audio, video, 3-D, graphics, image, and speech processing. The PXP 108 is a hardware lookup table (LUT) that can be used to process graphics data or composite video and graphics data before sending such data to an LCD display or TV encoder. The PXP 108 is capable of scaling, color space conversion (CSC) between YUV and RGB color spaces, and alpha-blending.
The controller 202 comprises a central processing unit (CPU) 112 for providing new pixel state data in an update buffer 122, current pixel state data in a working buffer 120, and current operating parameters. A memory 118 stores an overall table 208 of waveform data corresponding to different transitions of pixels from all pixel states to all other pixel states according to different operating parameters.
A hardware lookup table (LUT) module 108 receives input values containing new pixel state data 300 (
The LUT module 108 has LUT output memory space 210 and LUT table memory space 212. The LUT table memory space 212 stores mapping values 400 (
A single-instruction multiple-data (SIMD) module 126 transposes the segments of waveform data from the LUT output memory space 210, and places the transposed waveform data 500 in respective frame scan buffers 206 (
The capacity of the LUT module 108 is insufficient to store the waveform data corresponding to the overall table 208 of all different transitions of pixels from current pixel states to other new pixel states according to different operating parameters, which may be of the order of 1 MByte for a 16-grayscale panel. The controller 202 breaks down the waveform data at run time to mapping values 400 that fit in the LUT table memory space 212 of the LUT module 108 for concurrent updates of groups of pixels. Pixels for a given update request will use the same operating parameters. Update requests #X to #(X+N) represent N update requests submitted in a period of time. The operating parameters of these requests may or may not be the same.
The current operating parameters that the CPU 112 provides may include operating temperature common to concurrent updates, and specific update mode and waveform mode for individual updates. These parameters are combined with a frame count to construct the mapping values 400 that are written to the LUT table memory space 212. The frame count is increased as the update process progresses.
The LUT module 108 may be a pixel processor PXP.
The SIMD module 126 may transpose the data in the LUT output memory space 210 to the format of the waveform data 500 corresponding to the LUT input values 300, 302, 304 for the update requests #X to #(X+N) and writes the transposed data into individual frame scan buffers 206. The process is much faster than a software extraction of the waveform data for each pixel.
The CPU 112 may provide the new pixel state data 300, current pixel state data 302 and allocate the indexes 304 for current updates to the LUT module 108. The new pixel state data 300 is first written to the working buffer 120, which contains current pixel state data 302 and indexes 304, and the LUT module 108 can then receive by direct memory access (DMA) the data from the working buffer 120, look up the mapping values 400 from the LUT table memory space 212 according to the LUT input values 300, 302, 304 and place them by DMA into the LUT output memory space 210 located in the DRAM 118.
The bit stream of waveforms for the EPD is a sequence of 2 bits data, corresponding to positive voltages, negative voltages, and neutral voltage. The size of the output from the LUT module 108 will define the number of frame scan buffers that can be generated at once in the LUT module 108. As the bit stream of the waveform for the EPD is a sequence of 2 bits data, it can generate simultaneously 8 (denoted as F) frame scan buffers for a maximum size of the output to the LUT module 108 of 16 bits. If a pixel does not belong to any active updates, the corresponding mapping value at the output of the LUT module 108 is zero.
As shown in
In an example implementation of the controller 202, the processing time for 8 individual frame scan buffers 206 with display resolution of 1440×1080 is 46 ms, leaving a margin relative to an equivalent frame refresh rate of 100 Hz. Glue Logic 600 is used to overcome incompatible active logic for some pins between the eLCDIF module 204 and the EPD panel 106. The glue logic 600 contains three inverters to convert three signals in the frame scan buffers 206 from active low to active high.
The invention may be implemented partially in a non-transitory machine-readable medium containing a computer program for running on a computer system, the program at least including code portions for performing steps of a method according to the invention when run on a programmable apparatus, such as a computer system or enabling a programmable apparatus to perform functions of a device or system according to the invention.
A computer process typically includes an executing (running) program or portion of a program, current program values and state information, and the resources used by the operating system to manage the execution of the process. An operating system (OS) is the software that manages the sharing of the resources of a computer and provides programmers with an interface used to access those resources. An operating system processes system data and user input, and responds by allocating and managing tasks and internal system resources as a service to users and programs of the system.
In the foregoing specification, the invention has been described with reference to specific examples of embodiments of the invention. It will, however, be evident that various modifications and changes may be made therein without departing from the broader spirit and scope of the invention as set forth in the appended claims.
Those skilled in the art will recognize that the boundaries between logic blocks are merely illustrative and that alternative embodiments may merge logic blocks or circuit elements or impose an alternate decomposition of functionality upon various logic blocks or circuit elements. Thus, it is to be understood that the architectures depicted herein are merely exemplary, and that in fact many other architectures can be implemented which achieve the same functionality. Similarly, any arrangement of components to achieve the same functionality is effectively “associated” such that the desired functionality is achieved. Hence, any two components combined to achieve a particular functionality can be seen as “associated with” each other such that the desired functionality is achieved, irrespective of architectures or intermediate components. Likewise, any two components so associated can also be viewed as being “operably connected”, or “operably coupled”, to each other to achieve the desired functionality.
Furthermore, those skilled in the art will recognize that boundaries between the above described operations merely illustrative. The multiple operations may be combined into a single operation, a single operation may be distributed in additional operations and operations may be executed at least partially overlapping in time. Moreover, alternative embodiments may include multiple instances of a particular operation, and the order of operations may be altered in various other embodiments.
Also for example, in one embodiment, the illustrated examples of the controller 202 may be implemented as circuitry located on a single integrated circuit or within a same device. Alternatively, the modules of the controller 202 may be implemented as any number of separate integrated circuits or separate devices interconnected with each other in a suitable manner.
In the claims, the word ‘comprising’ or ‘having’ does not exclude the presence of other elements or steps then those listed in a claim. Furthermore, the terms “a” or “an,” as used herein, are defined as one or more than one. Also, the use of introductory phrases such as “at least one” and “one or more” in the claims should not be construed to imply that the introduction of another claim element by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim element to inventions containing only one such element, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an”. The same holds true for the use of definite articles. Unless stated otherwise, terms such as “first” and “second” are used to arbitrarily distinguish between the elements such terms describe. Thus, these terms are not necessarily intended to indicate temporal or other prioritization of such elements. The mere fact that certain measures are recited in mutually different claims does not indicate that a combination of these measures cannot be used to advantage.
Number | Date | Country | Kind |
---|---|---|---|
2014 1 0858356 | Dec 2014 | CN | national |
Number | Name | Date | Kind |
---|---|---|---|
5392385 | Evangelisti | Feb 1995 | A |
7511722 | Ollmann | Mar 2009 | B1 |
8730152 | Hare et al. | May 2014 | B2 |
20120147016 | Ishikawa | Jun 2012 | A1 |
20120188272 | Wang | Jul 2012 | A1 |
20120229436 | Rhodes | Sep 2012 | A1 |
20140285479 | Yamada | Sep 2014 | A1 |
20150371602 | Muto | Dec 2015 | A1 |
20160004293 | Park | Jan 2016 | A1 |
Entry |
---|
W.-C. Kao, “Electrophoretic Display Controller Integrated with Real-Time Halftoning and Partial Region Update”, Journal of Display Technology, vol. 6, No. 1, Jan. 2010, pp. 36-44. |
Number | Date | Country | |
---|---|---|---|
20160171922 A1 | Jun 2016 | US |