The present invention relates generally to bistable, electro-optic display devices and more particularly to automatically configuring update operations for a bistable, electro-optic display device.
A display device is comprised of an array of pixels. “Electro-optic” refers to an effect in which the optical properties of a material change in response to an electric field. Optical properties may include, but are not limited, to visual appearance. A display device in which the optical properties of the pixels may be made to change in response to an electric field is an electro-optic display device. Generally, if a pixel has two stable states, it may be considered bistable. However, the term “bistable” is used herein to mean multi-stable, i.e., pixels may have two or more stable states. For an optical property of a pixel to be considered stable, it is required that the property remain stable for a non-temporary period of time. Such a time period may be considered non-temporary if it is four times the minimum duration of a driving signal required to produce the electric field or fields needed to change the optical property of a pixel.
A variety of bistable, electro-optic display devices are known. One type of bistable, electro-optic display employs rotating bichromal bodies. A large number of small bodies having two or more sections with differing optical characteristics and an internal dipole are suspended in minute, liquid-filled cavities of a matrix. The bodies may be made to rotate by applying an electric field. Another type of bistable, electro-optic display uses an electrochromic medium. Yet another type of electro-optic display employs electro-wetting.
One type bistable, electro-optic display device is based on electrophoresis, that is, the movement of charged particles in response to an electric field. In displays of this type, charged particles are made to move through a fluid by application of an electric field. The fluid may be liquid or gas. The particles may be enclosed in a capsule, and the particles, fluid, capsules, and other elements may be collectively referred to as “encapsulated electrophoretic media.” Typically, encapsulated electrophoretic media comprise numerous small capsules, and the capsules are held within a polymeric binder to form a coherent layer positioned between two electrodes. Displays of this type may be referred to as microencapsulated electrophoretic (“MEP”) displays or electrophoretic displays (“EPDs”).
A “micro-cell” electrophoretic display is another type of EPD. In a micro-cell electrophoretic display, the charged particles and the suspending fluid are retained within a plurality of cavities formed within a carrier medium, typically a polymeric film.
EPDs may be made so that they can be updated using a thin-film transistor (“TFT”) array similar to those employed in active matrix LCDs, in which case the EPD may be referred to as an active matrix EPD (“AMPED”). EPDs are a promising technology for use in electronic readers or “e-books” because they provide good readability in a variety of lighting conditions, including sunlight. In addition, they consume low amounts of power compared with LCDs.
EPDs have been designed to operate using several different update modes. A “monochrome” update mode may be used to refresh an image comprised entirely of black and white pixels, such as text. An image of this type may also be referred to as a bi-level or bit-mapped image. A gray-scale update mode is used to refresh an image comprised of pixels that may be black, white, or a shade of gray in between black and white.
The time required to refresh an EPD in different update modes varies. For example, one exemplary monochrome update mode may require about one-third of the time an exemplary gray-scale update mode may require to update the EPD. It is generally desirable to use the fastest available update mode. However, the use of an incorrect update mode may result in image artifacts.
The image displayed on an EPD may only need to be refreshed every ten minutes or so, or when the image changes. For this reason, a CPU or other image data source generally needs to specifically request an image update. When the CPU requests an image update, it needs to specify an update mode and additional parameters.
There is a technical problem with known EPD s. Specifically, a CPU or other source of image data must specify an update mode and additional parameters. However, the information needed to determine the required update mode and other parameters may not be readily available to the CPU. Further, the determination of parameter values may place a significant burden on the CPU.
Accordingly, there is a need for methods and apparatus that simplify the interface between a CPU or other source of image data and a bistable, electro-optic display device, such as an EPD.
An apparatus embodying principles of the invention includes first and second units, and at least one pipeline unit. The first unit generates synthesized pixel data from pixels of an image and pixels of a previous image. The second unit determines an update mode by comparing pixels of the image with corresponding pixels of the previous image to determine if at least one condition is true. The condition or conditions may be configurable. In addition, the second unit selects an update mode from two or more update modes if the first condition is true. The pipeline unit determines a waveform for each pixel of the image and transmits the waveform as impulse data to a bistable, electro-optic display device.
The apparatus may further include a pipeline selecting unit to select a pipeline from two or more pipelines according to the selected update mode.
A bistable, electro-optic display device and a method embodying principles of the invention are also disclosed.
Methods and apparatus according to the principles of the invention simplify the interface between a CPU or other source of image data (“host”) and a bistable, electro-optic display device by freeing the host from having to determine the best update mode to use and which pipeline to use.
This summary is provided to generally describe what follows in the drawings and detailed description and is not intended to limit the scope of the invention. Objects, features, and advantages of the invention will be readily understood upon consideration of the following detailed description taken in conjunction with the accompanying drawings.
In the drawings and description below, the same reference numbers are used in the drawings and the description generally to refer to the same or like parts, elements, or steps.
A pixel may be driven to a black, white, or shade of gray intensity by applying a voltage pulse of appropriate polarity, duration, and amplitude to the electrodes of the pixel. The voltage pulse applied to a pixel may be modulated as to duration, amplitude, or both duration and amplitude. Moreover, the voltage pulse may be applied as single pulse or as two or more discrete pulses which approximate the single pulse.
In practice, the pixels in an electrophoretic display are typically driven by a pulse-train or “waveform.” The waveform used to drive a particular pixel depends on the new appearance or optical state of the pixel and a variety of other factors. One significant factor is the initial (or current) optical state of the pixel, as well as earlier optical states of the pixel. Other factors include temperature, and dwell time, i.e., how long the pixel was in the initial state before being driven to the new state.
EPDs may operate using several different update modes. A monochrome update mode may be used to refresh a bi-level image. A gray-scale update mode is used to refresh an image comprised of pixels that may be black, white, or a shade of gray in between black and white. A pen mode may be used to refresh an image that may be either bi-level or comprised of a plurality of gray levels. The pen mode updates the current image with bi-level pixels. Other update modes include modes in modes which the entire display is driven to white, black, or shade of gray. Each update mode employs a different drive scheme.
A drive scheme is the set of waveforms to drive any particular pixel from all possible optical states that the pixel may currently occupy to any possible new optical state. In other words, a drive scheme includes one waveform form for each possible pixel transition. The number of possible pixel transitions depends on the number of optical states that a specific electrophoretic display is capable of displaying. For bi-level pixels, there are two possible optical states and two possible transitions, black-to-white and white-to black. Thus, a bi-level drive scheme may comprise two waveforms. For 2-bit pixels, there are four possible states (black, dark-gray, light-gray, and white) and sixteen possible transitions. For 8-bit pixels, there are 64 four possible states and 4,096 possible transitions.
An update mode may include two or more sets of waveforms, each set for use with a specific type of electrophoretic display being operated in a specific environment, e.g., at specific temperatures.
A refresh operation typically begins after the host 22 has sent new pixels to the display controller 28, which are stored in the image buffer 78. The host 22 may store a full frame or less than a full frame in the image buffer 78. The host 22 may initiate a refresh operation at any time by sending the display controller 28 a “display image” or a “display partial image” command.
During an update operation, the pixel synthesizer 90 synthesizes pixel data to be used in the refresh operation, an update mode select unit 88 may select an update mode, and a pipe select unit 89 may select an update pipe 84.
In a refresh operation, the pixel synthesizer 90 fetches pixels from the image buffer 78 and the update buffer 82. At the instant a refresh operation is started, the next pixel NP corresponds with a pixel currently being displayed, and the current pixel CP corresponds with the previous optical state of the pixel. The pixel synthesizer 90 fetches a new pixel from the image buffer 78 and a corresponding next pixel NP from the update buffer 82. The pixel synthesizer 90 then stores the fetched pixels in the update buffer 82. In the synthesis operation, the new pixel fetched from the image buffer 78 is stored as a next pixel NP in the update buffer 90. The next pixel NP fetched from the update buffer 90 is stored as a current pixel CP in the update buffer 90, replacing the previously stored CP. In this way, the pixel synthesizer 90 stores pixel transitions with respect to the currently displayed and the next to be displayed images. The new NP, CP pair of pixels together defines a new pixel transition that may be used as an index for looking up waveform data. While the image buffer 78 may be unavailable to the host 22 during the pixel synthesis operation, generally speaking, the synthesis operation may be performed quickly and consumes only a small portion of the total refresh operation time.
The update mode select unit 88 may select an update mode. Turing to
An exemplary compare unit 92 is shown in greater detail in
The parameter for the threshold compare module 100 may be the minimum pixel value difference between the current and next pixel. In one embodiment, the parameter may take any value between 0 and 255. If the difference between the current and next pixel is greater than or equal to the difference parameter, then the result of the comparison is true and the threshold compare module 100 asserts a one on its output. Otherwise, it is false, i.e., zero. As one example, if the difference parameter is set to 255, then the comparison result is only true in two cases: if CP=0 and NP=255, or if CP=255 and NP=0. In one alternative, a maximum pixel value difference may be substituted for the minimum difference.
The parameter for the current pixel compare module 102 may be a value for the current pixel. If the current pixel CP is equal to the current pixel parameter value, the comparison result is true and the current pixel compare module 102 outputs a one. Otherwise, a zero is output. As one example, if pixel states are defined by eight bits and if the CP compare parameter is set to 255, then the comparison result is true in 256 cases: if CP=255 and NP=0-255. In one alternative, the parameter for the current pixel compare module 102 may be a value for a pixel earlier in time than the current pixel, e.g., the pixel value immediately preceding the current pixel value.
Similarly, the parameter for the next pixel compare module 104 may be a value for the next pixel. If the next pixel NP is equal to the next pixel parameter value, the comparison result is true and the next pixel compare module 104 asserts a one on its output. Otherwise, a zero is output. For instance, if pixel states are defined by eight bits and if the NP compare parameter is set to 255, then the comparison result is true in 256 cases: if CP=0-255 and NP=255.
The threshold compare module 100 is always enabled, but it may be effectively disabled by specifying the difference as zero. The next and current pixel compare modules 102, 104 may be enabled or disabled by the signals CP_EN signal and NP_EN respectively. In operation, a register R is reset to a logic 1 (or true) at the start of a new frame. If at any time during the pixel-by-pixel comparison process, a comparison result is false, the register R is reset to a logic 2 (or false). The threshold compare module 100 may be used to detect a monochrome type pixel transitions and that the compare modules 102, 104 may be used to detect pen type pixel transitions. It may be seen that the modules may be programmed to detect a wide variety of other pixel transitions.
Referring again to
Table 1 below further illustrates the operation of the update mode select unit 88 of
As can be seen from Table 1, the compare unit 0 detects only the pixel transitions from black-to-white and from white-to-black. If these are the only transitions in the update area, the MU set of waveforms are selected. The compare units 1 and 2 each detect one-half of all possible PU type transitions.
A refresh operation may update the full display area. Alternatively, the full display area may be divided into two or more sub-areas or regions. The host 22 may use the display partial image command to display one region of a full frame. An update pipe 84 may be used to refresh the full display area or one region of the full display area.
In one embodiment, the refresh operations for two or more regions may proceed in parallel, each update being performed by a separate update pipe 84. In addition, the refresh operation for each region may use a different update mode. The update mode select unit 88 may be employed to determine an update mode for a full frame. Alternatively, the update mode select unit 88 may be employed to determine an update mode for one or more regions of a frame.
One advantage of the update mode select unit 88 is that it frees the host 22 from having to determine the best update mode to use. In addition, software operating on the host 22 may be comprised of layers, where a lower layer provides a service to a higher layer, but at the same time shields or hides implementation details from the higher layer. The update mode select unit 88 permits the use of display image and display partial image commands by software operating at a higher level without requiring that the software keep track of previous images so as to be able to determine the fastest update mode. Not only does this simplify the design of higher level software, it provides a safeguard against inadvertent mistakes by software in selecting a non-permitted update mode. Moreover, the configurability of the update mode select unit 88 provides a substantial advantage because the display controller 28 may be easily adapted for use with update modes other than those described herein or with newly developed update modes as they become available.
In one embodiment, the pipe select unit 89 selects an update pipe 84. The output of the update mode select unit 88, i.e., the best update mode for a full frame or a region, is provided to the pipe select unit 89. The pipe select unit 89 may use the update mode so provided to select an update pipe. One possible way that the pipe select unit 89 may select an update pipe is shown in Table 2 below.
The exemplary pipe allocation scheme shown in Table 2 assumes that sixteen update pipes 84 are provided in the display controller 28. The scheme shown in Table 2 is effective to balance the load of updating the display 26 because the relatively fast update modes are provided with relatively fewer update pipes, while the relatively slow update mode is provided with relatively more update pipes. Specifically, the mono and pen update modes may, in one embodiment, require on the order of 260 ms, and the gray-scale update mode requires on the order of 800 ms. In other words, a refresh operation in gray-scale update mode may take three times as long as a refresh operation in one of the other update modes, irrespective of size of the region to be updated. (The time period for a refresh operation is generally about the same without regard to the number of pixels being updated.) By allocating fifty percent of the available update pipes 84 to the update mode that takes three times as long as the other update modes, it is unlikely that the display partial image command will have to wait because all available display pipes are busy.
While the allocation scheme described above has been provided as one example, it will be appreciated that other one possible allocation schemes, providing similar load balancing benefits may be implemented using the determined update mode. Other allocation schemes may take into account the expected types of updates in a particular application.
In operation, an update pipe 84 selected by the pipe select unit 89 reads synthesized pixel data for its assigned region from the update buffer 82 and generates waveforms for the pixels of the specified region.
One advantage of the pipe select unit 89 is that it frees the host 22 from having to determine which update pipe 84 to use when it issues a display full or partial image command. Another advantage of the pipe select unit 89 is that it is unlikely that a display image command will need to wait for a free update display pipe 84.
To generate waveforms, each pixel transition is used as a waveform lookup table index. Waveforms may be stored in the waveform memory 34. In one embodiment, the memory 34 may be a serial flash memory. An update pipe 84 locates the set of all possible waveforms in the waveform memory 34 corresponding with a specified update mode provided to the pipe by the update mode select unit 88.
The array of pixels or “frame” which makes up the display are addressed in raster order. The amount of time it takes to scan all of the pixels in the frame is the frame period. If the waveform is comprised of a single pulse, the waveform may have a duration of one frame. However, waveforms typically have two or more pulses, and accordingly, a waveform is typically presented to the display 26 in two or more frames.
The voltage of the pulses in a frame may be a single voltage amplitude having either a positive or negative polarity. For example, the voltage amplitude may be either +15V, −15V. Alternatively, the voltage of the pulses may be a positive or negative voltage, or zero volts. For example, the voltage amplitude may be either +15V, −15V, or 0V. However, it is not required that pulses be limited to two or three possible amplitudes. A waveform for driving a pixel may have as many different amplitude magnitudes as desired.
For each frame in the update mode period, the pipe 84 copies the impulses for all of the pixel transitions for the current frame and stores the current frame impulses in a lookup table within the pipe. However, the pipe 84 does not copy entire waveforms in each frame; only the portion of the waveform pertinent to the current frame is copied, e.g., one pulse. In addition, for each frame, the update pipe 88 fetches pixel transitions for its assigned region from the update buffer 88 in raster order. Using the current frame impulse data stored in the lookup table in the pipe, the update pipe 84 locates impulse data for the current frame corresponding with each fetched pixel transition. The update pipe 84 provides the impulse data to the timing generation unit 86.
The timing generation unit 86 steps through the locations of an image in raster order every frame period, selecting impulse data corresponding with the current pixel position from one of the update pipes 84. The timing generation unit 86 is provided with coordinate locations of each designated region along with the update pipe 84 to which the region has been assigned. The timing generation unit 86 provides the selected impulse data to the display panel 26 and the display power module 38.
It will be appreciated that the system 20 may include components in addition to those described above. In addition, the display controller 26 may perform may include additional modules, units, or components. In order to not needlessly complicate the present disclosure, only modules, units, or components believed to be necessary for understanding the principles of the claimed inventions have been described.
In one embodiment, the update mode select module or the pipe select module may perform some or all of the operations and methods described in this description by executing instructions that are stored in or on machine-readable media.
In this description, references may be made to “one embodiment” or “an embodiment.” These references mean that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the claimed inventions. Thus, the phrases “in one embodiment” or “an embodiment” in various places are not necessarily all referring to the same embodiment. Furthermore, particular features, structures, or characteristics may be combined in one or more embodiments.
Although embodiments have been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Accordingly, the described embodiments are to be considered as illustrative and not restrictive, and the claimed inventions are not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims. Further, the terms and expressions which have been employed in the foregoing specification are used as terms of description and not of limitation, and there is no intention in the use of such terms and expressions to exclude equivalents of the features shown and described or portions thereof, it being recognized that the scope of the inventions are defined and limited only by the claims which follow.