This disclosure relates to methods and systems for displaying an input image using different halftoning methods based on the frame rate of a display device.
Electromechanical systems (EMS) include devices having electrical and mechanical elements, actuators, transducers, sensors, optical components such as mirrors and optical films, and electronics. EMS devices or elements can be manufactured at a variety of scales including, but not limited to, microscales and nanoscales. For example, microelectromechanical systems (MEMS) devices can include structures having sizes ranging from about a micron to hundreds of microns or more. Nanoelectromechanical systems (NEMS) devices can include structures having sizes smaller than a micron including, for example, sizes smaller than several hundred nanometers. Electromechanical elements may be created using deposition, etching, lithography, and/or other micromachining processes that etch away parts of substrates and/or deposited material layers, or that add layers to form electrical and electromechanical devices.
One type of EMS device is called an interferometric modulator (IMOD). The term IMOD or interferometric light modulator refers to a device that selectively absorbs and/or reflects light using the principles of optical interference. In some implementations, an IMOD display element may include a pair of conductive plates, one or both of which may be transparent and/or reflective, wholly or in part, and capable of relative motion upon application of an appropriate electrical signal. For example, one plate may include a stationary layer deposited over, on or supported by a substrate and the other plate may include a reflective membrane separated from the stationary layer by an air gap. The position of one plate in relation to another can change the optical interference of light incident on the IMOD display element. IMOD-based display devices have a wide range of applications, and are anticipated to be used in improving existing products and creating new products, especially those with display capabilities.
Some display devices, such as, for example EMS systems based display devices, can produce an input color by utilizing more than three primary colors. Each of the primary colors can have reflectance or transmittance characteristics that are independent of each other. Such devices can be referred to as multi-primary display devices. In multi-primary display devices there may be more than one combination of the multiple primary colors to produce the same color having input color values, such as red (R), green (G), and blue (B) values.
The systems, methods and devices of this disclosure each have several innovative aspects, no single one of which is solely responsible for the desirable attributes disclosed herein.
One innovative aspect of the subject matter described in this disclosure can be implemented an apparatus comprising a display device including a plurality of display elements, each display element capable of displaying N primary colors in a color space associated with the display device and a computing device capable of communicating with the display device. The computing device is capable of processing image data that includes a plurality of input colors for display by the display device. The image data includes a plurality of image pixels with each image pixel associated with an input image pixel color. For a given image pixel, the computing device is further capable of identifying, from a color palette including colors capable of being displayed by temporal dithering of the N primary colors in M temporal sub-frames, K colors in a neighborhood of the input image pixel color. The computing device is capable of calculating weights for the identified K colors such that a color combination produced by blending the K colors with the corresponding weights produces a color that is perceptually similar to the input image pixel color. The computing device is further capable of determining a display color from the color palette based at least in part on the calculated weights and a rank order given by a halftone screen for the given image pixel. The halftone screen is associated with a block of the display elements of the display device. The computing device is further capable of assigning the display color to a display element of the display device that corresponds to the image pixel. In various implementations, the apparatus can further include a non-transitory memory device that is capable of communicating with the computing device. The non-transitory memory device can be configured to store the halftone screen. In various implementations, the halftone screen can be stored as a look-up-table (LUT). In various implementations, the look-up table (LUT) can also be used to store a correspondence between the display color and the set of primary colors.
In various implementations, to identify the K colors, the computing device can be capable of identifying the K colors that form a polyhedron that includes the input image pixel color in a color space associated with the color palette. In various implementations, the polyhedron can be a tetrahedron. In various implementations, the computing device can be capable of calculating a volume of a sub-tetrahedron that includes a face of the tetrahedron and a vertex corresponding to the input image pixel color. In various implementations, the halftone screen can include an array having more than 32×32 values. In various implementations, the computing device can be capable of determining the display color based at least in part on a comparison of the rank order for the given image pixel with a threshold value. The threshold value can be based at least in part on one or more of the weights.
In various implementations, the display device can be a reflective display device. In various implementations, at least some of the plurality of display elements can include a movable mirror. Each of the N primary colors can correspond to a distinct position of the movable mirror. In various implementations, the display device can be capable of operating at a frame rate greater than or equal to a threshold frame rate. The number M of temporal sub-frames can be at least 2. In various implementations, the display device can be configured to operate at a frame rate less than the threshold frame rate and without using temporal dithering. In various implementations, the threshold frame rate can be about 60 Hz. In various implementations, the computing device can be capable of identifying a set of primary colors that corresponds to the display color; and respectively displaying each of the primary colors in the set in one of the M temporal sub-frames.
Another innovative aspect of the subject matter described in this disclosure can be implemented in a computer-implemented method to display image data on a display device including a plurality of display elements. Each display element is capable of displaying N primary colors in a color space associated with the display device. The image data includes a plurality of input colors for display by the display device. The image data includes a plurality of image pixels. Each image pixel is associated with an input image pixel color. The method is performed under control of a hardware computing device associated with the display device.
For a given image pixel, the method comprises identifying, from a color palette including colors capable of being displayed by temporal dithering of the N primary colors in M temporal sub-frames, K colors in a neighborhood of the input image pixel color. The method further comprises calculating weights for the identified K colors such that a color combination produced by blending the K colors with the corresponding weights produces a color that is perceptually similar to the input image pixel color. The method further comprises determining a display color from the color palette based at least in part on the calculated weights and a rank order given by a halftone screen for the given image pixel, the halftone screen associated with a block of the display elements of the display device. The method comprises assigning the display color to one or more of the plurality of display elements of the display device that corresponds to the image pixel.
In various implementations, identifying the K colors can include identifying the K colors that form a polyhedron that includes the input image pixel color in a color space associated with the color palette. In various implementations, calculating the weights can include calculating a volume of a sub-polyhedron that includes a face of the polyhedron and a vertex corresponding to the input image pixel color.
Another innovative aspect of the subject matter described in this disclosure can be implemented in a non-transitory computer storage medium comprising instructions that when executed by a processor cause the processor to perform a method for displaying image data including a plurality of input colors on a display device. The display device includes a plurality of display elements. Each display element is capable of displaying N primary colors in a color space associated with the display device. The image data includes a plurality of image pixels with each image pixel associated with an input image pixel color. For a given image pixel, the method comprises identifying, from a color palette including colors capable of being displayed by temporal dithering of the N primary colors in M temporal sub-frames, K colors in a neighborhood of the input image pixel color. The method further comprises calculating weights for the identified K colors such that a color combination produced by blending the K colors with the corresponding weights produces a color that is perceptually similar to the input image pixel color. The method further comprises determining a display color from the color palette based at least in part on the calculated weights and a rank order given by a halftone screen for the given image pixel, the halftone screen associated with a block of the display elements of the display device. The method further comprises assigning the display color to one or more of the plurality of display elements of the display device that corresponds to the image pixel.
In various implementations of the method, identifying the K colors can include identifying the K colors that form a polyhedron that includes the input image pixel color in a color space associated with the color palette. In various implementations of the method calculating the weights can include calculating a volume of a sub-polyhedron that includes a face of the polyhedron and a vertex corresponding to the input image pixel color.
Details of one or more implementations of the subject matter described in this disclosure are set forth in the accompanying drawings and the description below. Although the examples provided in this disclosure are primarily described in terms of EMS and MEMS-based displays the concepts provided herein may apply to other types of displays such as liquid crystal displays, organic light-emitting diode (“OLED”) displays, and field emission displays. Other features, aspects, and advantages will become apparent from the description, the drawings and the claims. Note that the relative dimensions of the following figures may not be drawn to scale.
Like reference numbers and designations in the various drawings indicate like elements.
The following description is directed to certain implementations for the purposes of describing the innovative aspects of this disclosure. However, a person having ordinary skill in the art will readily recognize that the teachings herein can be applied in a multitude of different ways. The described implementations may be implemented in any device, apparatus, or system that can be configured to display an image, whether in motion (such as video) or stationary (such as still images), and whether textual, graphical or pictorial. More particularly, it is contemplated that the described implementations may be included in or associated with a variety of electronic devices such as, but not limited to: mobile telephones, multimedia Internet enabled cellular telephones, mobile television receivers, wireless devices, smartphones, Bluetooth® devices, personal data assistants (PDAs), wireless electronic mail receivers, hand-held or portable computers, netbooks, notebooks, smartbooks, tablets, printers, copiers, scanners, facsimile devices, global positioning system (GPS) receivers/navigators, cameras, digital media players (such as MP3 players), camcorders, game consoles, wrist watches, clocks, calculators, television monitors, flat panel displays, electronic reading devices (e.g., e-readers), computer monitors, auto displays (including odometer and speedometer displays, etc.), cockpit controls and/or displays, camera view displays (such as the display of a rear view camera in a vehicle), electronic photographs, electronic billboards or signs, projectors, architectural structures, microwaves, refrigerators, stereo systems, cassette recorders or players, DVD players, CD players, VCRs, radios, portable memory chips, washers, dryers, washer/dryers, parking meters, packaging (such as in electromechanical systems (EMS) applications including microelectromechanical systems (MEMS) applications, as well as non-EMS applications), aesthetic structures (such as display of images on a piece of jewelry or clothing) and a variety of EMS devices. The teachings herein also can be used in non-display applications such as, but not limited to, electronic switching devices, radio frequency filters, sensors, accelerometers, gyroscopes, motion-sensing devices, magnetometers, inertial components for consumer electronics, parts of consumer electronics products, varactors, liquid crystal devices, electrophoretic devices, drive schemes, manufacturing processes and electronic test equipment. Thus, the teachings are not intended to be limited to the implementations depicted solely in the Figures, but instead have wide applicability as will be readily apparent to one having ordinary skill in the art.
The systems and methods described herein can be used to display high bit-depth color images (e.g., images having 8 bits per color channel) on a display device including a plurality of display elements having lower color bit-depth (for example, 1, 2 or 4 bits per color channel). Each display element of the display device can produce multiple primary colors (for example, greater than four (4) or six (6)) in a color space associated with the display device. To display high bit-depth color images (for example, with 8 bits per color channel or 256 color levels per color channel) on a multi-primary display device, temporal modulation/dithering and/or spatial modulation can be used. For example, using temporal modulation/dithering with four temporal frames and black and white colors, five colors including three gray levels can be displayed. As another example, using temporal modulation/dithering with two temporal frames and black, white and a primary color (e.g., red, green or blue), six colors can be displayed. Many different color levels can be produced by including more primary colors and temporal frames.
Systems and methods described herein can be used for rendering static images as well as video (e.g., video with fast moving objects). The systems and methods described herein can be used in display devices have two modes of operation. In a first mode, the display device is configured to operate at a frame rate of 60 Hz or higher (e.g., 120 Hz, 240 Hz, etc.). In a second mode, the display device is configured to operate at a frame rate less than 60 Hz (e.g., 30 Hz). In the first mode images and/or video are displayed using spatial vector screening and/or temporal dithering to provide high image quality with few temporal artifacts. In the second mode, images and/or video are displayed using vector error diffusion. The display device can include a sensor that senses the status of the display device and is capable of switching the display device between the two modes. In various implementations, the display device can include an output buffer to store the indices for the primary colors and/or the last input image. A look-up table (LUT) can be used to store a correspondence between the display color and the set of primary colors. In various implementations, the output buffer can be configured to store the last input image and display the last input image when the display device is operated in the always-on mode.
Particular implementations of the subject matter described in this disclosure can be implemented to realize one or more of the following potential advantages. It is possible to display high bit-depth digital images on display devices having low native bit-depth multiple primary colors to render intermediate tones that cannot be natively displayed by the display device. It is possible to switch the display between a first mode in which the display device is configured to operate at a fast frame rate and a second mode in which the display device is configured to operate at a slower frame rate. In the first mode, the display device can be configured to display images and/or videos with few visual artifacts. In the second mode, the display device can be configured to display images with reduced power consumption. In various implementations, the display device can be configured to operate in the second mode when it is desirable to save energy.
An example of a suitable EMS or MEMS device or apparatus, to which the described implementations may apply, is a reflective display device. Reflective display devices can incorporate interferometric modulator (IMOD) display elements that can be implemented to selectively absorb and/or reflect light incident thereon using principles of optical interference. IMOD display elements can include a partial optical absorber, a reflector that is movable with respect to the absorber, and an optical resonant cavity defined between the absorber and the reflector. In some implementations, the reflector can be moved to two or more different positions, which can change the size of the optical resonant cavity and thereby affect the reflectance of the IMOD. The reflectance spectra of IMOD display elements can create fairly broad spectral bands that can be shifted across the visible wavelengths to generate different colors. The position of the spectral band can be adjusted by changing the thickness of the optical resonant cavity. One way of changing the optical resonant cavity is by changing the position of the reflector with respect to the absorber.
The IMOD display device can include an array of IMOD display elements which may be arranged in rows and columns. Each display element in the array can include at least a pair of reflective and semi-reflective layers, such as a movable reflective layer (i.e., a movable layer, also referred to as a mechanical layer) and a fixed partially reflective layer (i.e., a stationary layer), positioned at a variable and controllable distance from each other to form an air gap (also referred to as an optical gap, cavity or optical resonant cavity). The movable reflective layer may be moved between at least two positions. For example, in a first position, i.e., a relaxed position, the movable reflective layer can be positioned at a distance from the fixed partially reflective layer. In a second position, i.e., an actuated position, the movable reflective layer can be positioned more closely to the partially reflective layer. Incident light that reflects from the two layers can interfere constructively and/or destructively depending on the position of the movable reflective layer and the wavelength(s) of the incident light, producing either an overall reflective or non-reflective state for each display element. In some implementations, the display element may be in a reflective state when unactuated, reflecting light within the visible spectrum, and may be in a dark state when actuated, absorbing and/or destructively interfering light within the visible range. In some other implementations, however, an IMOD display element may be in a dark state when unactuated, and in a reflective state when actuated. In some implementations, the introduction of an applied voltage can drive the display elements to change states. In some other implementations, an applied charge can drive the display elements to change states.
The depicted portion of the array in
In
The optical stack 16 can include a single layer or several layers. The layer(s) can include one or more of an electrode layer, a partially reflective and partially transmissive layer, and a transparent dielectric layer. In some implementations, the optical stack 16 is electrically conductive, partially transparent and partially reflective, and may be fabricated, for example, by depositing one or more of the above layers onto a transparent substrate 20. The electrode layer can be formed from a variety of materials, such as various metals, for example indium tin oxide (ITO). The partially reflective layer can be formed from a variety of materials that are partially reflective, such as various metals (e.g., chromium and/or molybdenum), semiconductors, and dielectrics. The partially reflective layer can be formed of one or more layers of materials, and each of the layers can be formed of a single material or a combination of materials. In some implementations, certain portions of the optical stack 16 can include a single semi-transparent thickness of metal or semiconductor which serves as both a partial optical absorber and electrical conductor, while different, electrically more conductive layers or portions (e.g., of the optical stack 16 or of other structures of the display element) can serve to bus signals between IMOD display elements. The optical stack 16 also can include one or more insulating or dielectric layers covering one or more conductive layers or an electrically conductive/partially absorptive layer.
In some implementations, at least some of the layer(s) of the optical stack 16 can be patterned into parallel strips, and may form row electrodes in a display device as described further below. As will be understood by one having ordinary skill in the art, the term “patterned” is used herein to refer to masking as well as etching processes. In some implementations, a highly conductive and reflective material, such as aluminum (Al), may be used for the movable reflective layer 14, and these strips may form column electrodes in a display device. The movable reflective layer 14 may be formed as a series of parallel strips of a deposlited metal layer or layers (orthogonal to the row electrodes of the optical stack 16) to form columns deposited on top of supports, such as the illustrated posts 18, and an intervening sacrificial material located between the posts 18. When the sacrificial material is etched away, a defined gap 19, or optical cavity, can be formed between the movable reflective layer 14 and the optical stack 16. In some implementations, the spacing between posts 18 may be approximately 1-1000 μm, while the gap 19 may be approximately less than 10,000 Angstroms (A).
In some implementations, each IMOD display element, whether in the actuated or relaxed state, can be considered as a capacitor formed by the fixed and moving reflective layers. When no voltage is applied, the movable reflective layer 14 remains in a mechanically relaxed state, as illustrated by the display element 12 on the left in
The processor 21 can be configured to communicate with an array driver 22. The array driver 22 can include a row driver circuit 24 and a column driver circuit 26 that provide signals to, for example a display array or panel 30. The cross section of the IMOD display device illustrated in
In some implementations, a frame of an image may be created by applying data signals in the form of “segment” voltages along the set of column electrodes, in accordance with the desired change (if any) to the state of the display elements in a given row. Each row of the array can be addressed in turn, such that the frame is written one row at a time. To write the desired data to the display elements in a first row, segment voltages corresponding to the desired state of the display elements in the first row can be applied on the column electrodes, and a first row pulse in the form of a specific “common” voltage or signal can be applied to the first row electrode. The set of segment voltages can then be changed to correspond to the desired change (if any) to the state of the display elements in the second row, and a second common voltage can be applied to the second row electrode. In some implementations, the display elements in the first row are unaffected by the change in the segment voltages applied along the column electrodes, and remain in the state they were set to during the first common voltage row pulse. This process may be repeated for the entire series of rows, or alternatively, columns, in a sequential fashion to produce the image frame. The frames can be refreshed and/or updated with new image data by continually repeating this process at some desired number of frames per second.
The combination of segment and common signals applied across each display element (that is, the potential difference across each display element or pixel) determines the resulting state of each display element.
As illustrated in
When a hold voltage is applied on a common line, such as a high hold voltage VCHOLD
When an addressing, or actuation, voltage is applied on a common line, such as a high addressing voltage VCADD
In some implementations, hold voltages, address voltages, and segment voltages may be used which produce the same polarity potential difference across the modulators. In some other implementations, signals can be used which alternate the polarity of the potential difference of the modulators from time to time. Alternation of the polarity across the modulators (that is, alternation of the polarity of write procedures) may reduce or inhibit charge accumulation that could occur after repeated write operations of a single polarity.
In
The process 80 continues at block 84 with the formation of a sacrificial layer 25 over the optical stack 16. Because the sacrificial layer 25 is later removed (see block 90) to form the cavity 19, the sacrificial layer 25 is not shown in the resulting IMOD display elements.
The process 80 continues at block 86 with the formation of a support structure such as a support post 18. The formation of the support post 18 may include patterning the sacrificial layer 25 to form a support structure aperture, then depositing a material (such as a polymer or an inorganic material, like silicon oxide) into the aperture to form the support post 18, using a deposition method such as PVD, PECVD, thermal CVD, or spin-coating. In some implementations, the support structure aperture formed in the sacrificial layer can extend through both the sacrificial layer 25 and the optical stack 16 to the underlying substrate 20, so that the lower end of the support post 18 contacts the substrate 20. Alternatively, as depicted in
The process 80 continues at block 88 with the formation of a movable reflective layer or membrane such as the movable reflective layer 14 illustrated in
The process 80 continues at block 90 with the formation of a cavity 19. The cavity 19 may be formed by exposing the sacrificial material 25 (deposited at block 84) to an etchant. For example, an etchable sacrificial material such as Mo or amorphous Si may be removed by dry chemical etching by exposing the sacrificial layer 25 to a gaseous or vaporous etchant, such as vapors derived from solid XeF2 for a period of time that is effective to remove the desired amount of material. The sacrificial material is typically selectively removed relative to the structures surrounding the cavity 19. Other etching methods, such as wet etching and/or plasma etching, also may be used. Since the sacrificial layer 25 is removed during block 90, the movable reflective layer 14 is typically movable after this stage. After removal of the sacrificial material 25, the resulting fully or partially fabricated IMOD display element may be referred to herein as a “released” IMOD.
In some implementations, the packaging of an EMS component or device, such as an IMOD-based display, can include a backplate (alternatively referred to as a backplane, back glass or recessed glass) which can be configured to protect the EMS components from damage (such as from mechanical interference or potentially damaging substances). The backplate also can provide structural support for a wide range of components, including but not limited to driver circuitry, processors, memory, interconnect arrays, vapor barriers, product housing, and the like. In some implementations, the use of a backplate can facilitate integration of components and thereby reduce the volume, weight, and/or manufacturing costs of a portable electronic device.
The backplate 92 can be essentially planar or can have at least one contoured surface (e.g., the backplate 92 can be formed with recesses and/or protrusions). The backplate 92 may be made of any suitable material, whether transparent or opaque, conductive or insulating. Suitable materials for the backplate 92 include, but are not limited to, glass, plastic, ceramics, polymers, laminates, metals, metal foils, Kovar and plated Kovar.
As shown in
The backplate components 94a and/or 94b can include one or more active or passive electrical components, such as transistors, capacitors, inductors, resistors, diodes, switches, and/or integrated circuits (ICs) such as a packaged, standard or discrete IC. Other examples of backplate components that can be used in various implementations include antennas, batteries, and sensors such as electrical, touch, optical, or chemical sensors, or thin-film deposited devices.
In some implementations, the backplate components 94a and/or 94b can be in electrical communication with portions of the EMS array 36. Conductive structures such as traces, bumps, posts, or vias may be formed on one or both of the backplate 92 or the substrate 20 and may contact one another or other conductive components to form electrical connections between the EMS array 36 and the backplate components 94a and/or 94b. For example,
The backplate components 94a and 94b can include one or more desiccants which act to absorb any moisture that may enter the EMS package 91. In some implementations, a desiccant (or other moisture absorbing materials, such as a getter) may be provided separately from any other backplate components, for example as a sheet that is mounted to the backplate 92 (or in a recess formed therein) with adhesive. Alternatively, the desiccant may be integrated into the backplate 92. In some other implementations, the desiccant may be applied directly or indirectly over other backplate components, for example by spray-coating, screen printing, or any other suitable method.
In some implementations, the EMS array 36 and/or the backplate 92 can include mechanical standoffs 97 to maintain a distance between the backplate components and the display elements and thereby prevent mechanical interference between those components. In the implementation illustrated in
Although not illustrated in
In alternate implementations, a seal ring may include an extension of either one or both of the backplate 92 or the substrate 20. For example, the seal ring may include a mechanical extension (not shown) of the backplate 92. In some implementations, the seal ring may include a separate member, such as an O-ring or other annular member.
In some implementations, the EMS array 36 and the backplate 92 are separately formed before being attached or coupled together. For example, the edge of the substrate 20 can be attached and sealed to the edge of the backplate 92 as discussed above. Alternatively, the EMS array 36 and the backplate 92 can be formed and joined together as the EMS package 91. In some other implementations, the EMS package 91 can be fabricated in any other suitable manner, such as by forming components of the backplate 92 over the EMS array 36 by deposition.
Various implementations of a multi-primary display device can include the EMS array 36. The EMS elements in the array can include one or more IMODs. In some implementations the IMOD can include an analog IMOD (AIMOD). The AIMOD may be configured to selectively reflect multiple primary colors and provide 1 bit per color.
The reflective layer 906 can be actuated toward either the first electrode 910 or the second electrode 902 when a voltage is applied between the first and second electrodes 910 and 902. In this manner, the reflective layer 906 can be driven through a range of positions between the two electrodes 902 and 910, including above and below a relaxed (unactuated) state. For example,
The AIMOD 900 in
The AIMOD 900 can be configured to selectively reflect certain wavelengths of light depending on the configuration of the AIMOD. The distance between the first electrode 910, which in this implementation acts as an absorbing layer and the reflective layer 906 changes the reflective properties of the AIMOD 900. Any particular wavelength is maximally reflected from the AIMOD 900 when the distance between the reflective layer 906 and the absorbing layer (first electrode 910) is such that the absorbing layer (first electrode 910) is located at the minimum light intensity of standing waves resulting from interference between incident light and light reflected from the reflective layer 906. For example, as illustrated, the AIMOD 900 is designed to be viewed from the substrate 912 side of the AIMOD (through the substrate 912), that is, light enters the AIMOD 900 through the substrate 912. Depending on the position of the reflective layer 906, different wavelengths of light are reflected back through the substrate 912, which gives the appearance of different colors. These different colors are also referred to as native or primary colors. The number of primary colors produced by the AIMOD 900 can be greater than 4. For example, the number of primary colors produced by the AIMOD 900 can be 5, 6, 8, 10, 16, 18, 33, etc.
A position of the movable layer 906 at a location such that it reflects a certain wavelength or wavelengths can be referred to as a display state of the AIMOD 900. For example, when the reflective layer 906 is in position 930, red wavelengths of light are reflected in greater proportion than other wavelengths and the other wavelengths of light are absorbed in greater proportion than red. Accordingly, the AIMOD 900 appears red and is said to be in a red display state, or simply a red state. Similarly, the AIMOD 900 is in a green display state (or green state) when the reflective layer 906 moves to position 932, where green wavelengths of light are reflected in greater proportion than other wavelengths and the other wavelengths of light are absorbed in greater proportion than green. When the reflective layer 906 moves to position 934, the AIMOD 900 is in a blue display state (or blue state) and blue wavelengths of light are reflected in greater proportion than other wavelengths and the other wavelengths of light are absorbed in greater proportion than blue. When the reflective layer 906 moves to a position 936, the AIMOD 900 is in a white display state (or white state) and a broad range of wavelengths of light in the visible spectrum are substantially reflected such that and the AIMOD 900 appears “gray” or in some cases “silver,” and having low total reflection (or luminance) when a bare metal reflector is used. In some cases increased total reflection (or luminance) can be achieved with the addition of dielectric layers disposed on the metal reflector, but the reflected color may be tinted with blue, green or yellow, depending on the exact position of 936. In some implementations, in position 936, configured to produce a white state, the distance between the reflective layer 906 and the first electrode 910 is between about 0 and 20 nm. In other implementations, the AIMOD 900 can take on different states and selectively reflect other wavelengths of light based on the position of the reflective layer 906, and also based on materials that are used in construction of the AIMOD 900, particularly various layers in the optical stack 904.
The multiple primary colors displayed by a display element (for example, AIMOD 900) and the possible color combinations of the multiple primary colors displayed by a display element can represent a color space associated with the display element. A color in the color space associated with the display device can be identified by a color level that represents tone, grayscale, hue, chroma, saturation, brightness, lightness, luminance, correlated color temperature, dominant wavelength, or a coordinate in the color space associated with the display element.
There are many methods for spatial and temporal color blending. One method to render images and/or videos on a display device includes error diffusion. Without subscribing to any particular theory, error diffusion includes haftoning methods in which a color difference (or an error) between the color of an incoming image pixel and the color of the corresponding display pixel to which the incoming image pixel is mapped is distributed to neighboring pixels. Another method to render images and/or videos includes screening. Without subscribing to any particular theory, screening includes haftoning methods in which the color of an incoming image pixel light is compared with a screen that is constructed to have specific properties. The color of the corresponding display pixel to which the incoming image pixel is mapped is determined based on the comparison.
Without subscribing to any particular theory, error diffusion based approaches can render static images better than screening based methods. Without subscribing to any particular theory, screening based approaches can render video images better than error-diffusion based methods. Screening based approaches can be more robust to moving objects and have fewer motion artifacts while rendering videos of moving objects. Combining temporal dithering with error diffusion based or screening based methods can further increase image quality of rendered images.
The functional block 1005 is a color gamut mapping unit that is configured to receive an input image in a first color space and map it to a second color space. The second color space can be a color space associated with the display device. In various implementations, the first color space can be a sRGB color space and the second color space can be a linear RGB color space. In various implementations, the input image can be a 24-bit sRGB image and the image output from the color gamut mapping unit 1005 can be a 30-bit linear RGB image. The method further includes loading a look-up-table (LUT) as shown in block 1010 that can be accessed by the color gamut mapping unit 1005 to map the input image from the first color space to the second color space. The LUT can include colors in the second color space that correspond to the colors in the first color space. In various implementations, the LUT can be a 3D LUT interpolation unit with M×M×M vertices. In implementations where the first color space is a sRGB color space and the second color space is a linear RGB color space, M can have a value of 9. The LUT can be re-loadable for different illumination environments. In various implementations, the LUT can be generated using an interpolation method such as, for example, tetrahedral interpolation method.
The functional block 1015 in
The vector error diffusion based halftoning unit 1020 provides power-saving advantage when the display device is operating/running at frame rates lower than 60 Hz (e.g., 30 Hz). Vector error diffusion based halftoning can provide over-all higher quality than the screening dithering method for static images. Vector error diffusion based halftoning can also be used for generating an output image that can be saved in the output frame buffer 1035 for the always-on display (e.g., when the display module stops receiving video input from the host). An implementation of an image processing method employed by the vector error diffusion halftoning unit 1020 is discussed below with reference to
As discussed above, the vector screening and temporal dithering unit 1030 can be used to render videos or images having regions with color gradients while the vector error diffusion based halftoning unit 1020 can be used to render static images. However, in some implementations vector error diffusion based halftoning unit 1020 can be associated with visual artifacts that can reduce the image quality. The Vector screening and temporal dithering unit 1030 can provide good image quality for both static images and video streams. The standard display mode requires the display device running at a frame rate of 60 Hz or higher (e.g., 120 Hz). If the display input from host is also clocked with the same frame rate, the vector screening and temporal dithering unit 1030 can be used to process the display input, frame by frame, and send the corresponding halftone output to the output frame buffer 1035 for display by the display device. If the input has frame rates less than the display frame rate, the vector screening and temporal dithering unit 1030 can be used to process the input and send two-(or more) frame outputs to the output frame buffer 1035. The display device, running at 60 Hz or a higher frame rate, can cycle the two (or more) frame outputs in the output frame buffer 1035 until the buffer refreshed by the next frame output by the vector screening and temporal dithering halftoning unit 1030. Further details of vector screening and temporal dithering unit 1030 are discussed below.
The output frame buffer 1035 is configured to store output from the two halftoning units 1020 and 1030 described above. In various implementations, two or more frames can be used for the output generated by the vector screening and temporal dithering unit 1030 and only one frame is used for the output generated by the vector error diffusion based unit 1020. Besides being used for the situation when the frame rate of the display device is higher than the frame rate of the input signal, the output frame buffer 1035 can also provide the input for the input image retrieval unit as described below. In various implementations, the size of the required output frame buffer can be 400×400×2×4 bits, where 4 bits are used for storing the primary index for each pixel in each frame and 2 frames are used for a display device operating/running at 60 Hz. If the display device is operating/running at higher frame rate, the output buffer 1035 may contain more frames. For example, in various implementations, 3 frames may be used for a display device operating at 90 Hz frame rate and 4 frames may be used for a display device operating at 120 Hz frame rate.
It may be desirable to be able to switch back and forth between the two operation modes (standard and always-on mode). For example, when the host stops sending 60 Hz video input to the display running at 60 Hz, the system can be configured to retain the last frame image on display, the two halftone images stored in the output frame buffer 1035 may not be capable of providing acceptable halftone image for the always-on display. However, the combined information of the two halftone images in the output buffer bears a resemblance to the original last frame. The input image retrieval unit 1025 can be configured to translate the primary indices to RGB values and combine the two output frames to retrieve the original RGB input. The retrieved RGB input can be sent to the vector error diffusion based halftoning unit 1020 to obtain one-frame halftone output which can be used for the always-on display.
As discussed above, the color gamut mapping unit functional block 1005 can receive an input image in a first color space and map it to a second color space. The color gamut mapping unit 1005 can use a variety of methods to map the colors of an input image from a first color space to a second colors. For example, as discussed above, the colors of an input image can be mapped from a first color space to a second colors a tetrahedron interpolation method. The tetrahedron interpolation method can employ a three dimensional look-up table (LUT). In various implementations of the method 1000 illustrated in
Vector screening is a pixel-based halftoning method. The halftone output of each pixel by screening depends on the input RGB values of the pixel and a value on a halftone screen that is constructed to have specific properties associated with the pixel. In various implementations, the halftone screen can be a pre-determined two-dimensional matrix with specific values assigned to each matrix element. The halftone output of each pixel by vector error diffusion depends on the input RGB values of the pixel and the error associated with the processing of a neighboring pixel. In contrast to vector error diffusion, the output obtained by vector screening is influenced by neither the input nor the output of neighborhood pixels. Therefore, visual artifacts that may occur in other image rendering methods may not occur in vector screening. Although in general error diffusion based halftoning methods can provide shaper and smoother halftone images, vector screening may be advantageous for processing video streams. Vector screening can be implemented using a programmable circuit or a processor (for example, halftoning unit 1030).
Similar to error diffusion, screening based halftoning methods can be also categorized into two types: scalar screening and vector screening. A scalar screening method operates binary or multi-level thresholding in R, G and B channels independently to generate corresponding discrete R, G and B halftone outputs. The three halftone screens used in these three channels can be the same or different. Various implementations of the vector screening method discussed herein selects the halftone output in a vector manner in the 3D RGB space and uses only one halftone screen. An example of the vector screening process for a multi-primary display device (for example, a display device including an AIMOD 900) using four primary colors can be described as follows:
w
A
=V
OBCD
/V
ABCD, (1a)
w
B
=V
AOCD
/V
ABCD, (1b)
w
C
=V
ABOD
/V
ABCD, (1c)
w
D
=V
ABCO
/V
ABCD, (1d)
R
O
=w
A
*R
A
+w
B
*R
B
+w
C
*R
C
+w
D
*R
D, (2a)
G
O
=w
A
*G
A
+w
B
*G
B
+w
C
*G
C
+w
D
*G
D, (2b)
B
O
=w
A
*B
A
+w
B
*B
B
+w
C
*B
C
+w
D
*B
D, (2c)
P=A, if S(x,y)<NA, (3a)
P=B, if S(x,y)≧NA and S(x,y)<NA+NB, (3b)
P=C, if S(x,y)≧NA+NB and S(x,y)<NA+NB+NC, (3c)
P=D, if S(x,y)≧NA+NB+NC, (3d)
where NA=wAN,NB=wBN and NC=wCN. (3e)
For various implementations, the rank orders stored in the halftone screen, S(x, y), and the three weighting factors, NA, NB and NC, can be normalized into 8-bit integers, 0-255, for vector screening. Thus, a 128×128 halftone screen corresponds to 16K-byte memory space. Assuming the desired color is constant for all elements and it is within the tetrahedron defined by four primaries, A (yellow), B (red), C (brown) and D (cyan). The halftone screen shown in
The majority of the computation involved in the vector screening described above is calculating volumes of tetrahedrons. One way to calculate the volume of a tetrahedron is given by the following equation,
V
ABCD
=h
A
*A
BCD/6, (4)
a*R+b*G+c*B+d=0, (6)
The distance from the primary color A(RA, GA, BA) to this plane is given by the amplitude of
h
A=(a*RA+b*GA+c*BA+d)/√{square root over (a*a+b*b+c*c)}. (8)
Without detailed derivation, one may find that the three rank numbers, NA, NB and NC defined by Eq. 3e and used in Eqs. 3a-3d to determine the output primary P for a given location (x, y) and a given color (Ro, Go, Bo), can be summarized as a matrix computation given by Eq. 9.
All 12 coefficients mij in Eq. 9 are functions of the four primary colors, A (RA, GA, BA), B (RB, GB, BB), C (RC, GC, BC) and D (RD, GD, BD), and can be calculated using Eqs. 1-8. When 16 primary colors are used, only a limited number of tetrahedrons are used for the vector screening. For each of the chosen tetrahedron defined by four primary colors, the 12 coefficients mij can be pre-calculated and stored in a look-up-table. Therefore, once the tetrahedron, corresponding to a given input RGB color, (Ro, Go, Bo), is determined for each pixel, the required computation can be nine multiplications plus limited additions and comparisons. Some implementations of a method of searching the tetrahedron containing a given input color is discussed in the following section.
In various implementations of the multi-primary display device (for example, a display device including an AIMOD 900), only selected primary colors can be implemented for each element of the display module at any given time. To display colors not located on the spiral curve of SMI display in the color space, color dithering, or color blending of multiple primaries, spatially and/or temporally can be used. Different spatial dithering methods, such as, for example, vector error diffusion based halftoning and vector screening discussed above can be combined with temporal dithering methods to provide higher image quality and/or to reduce flicker as discussed below. In various implementations of a display device having a pixel pitch of 74 microns or less, or a spatial resolution of 343 PPI (pixels per inch) or less, the human visual system may not be able to resolve each individual pixel at a normal viewing distance. In such implementations, the colors perceived by human eyes may be the average of the colors displayed by a 2×2 pixel array. Temporally, the human visual system also has limited sensitivity to detect fast-changing acts and the sensitivity strongly depends on the contrast of the temporal changes.
However if the desired color 1505 is displayed by a combination of vector screening with temporal dithering, the number of primary colors can be increased beyond N selected primary colors. For example, for 16 selected primary colors, with 2 frames for temporal dithering, there are about 120 two primary color combinations that are available to display a desired color. The two primary combinations are the average colors obtained by temporally blending two different primaries, as illustrated in
The output of spatial and temporal combined dithering is a selected primary combination for each pixel. For K frames of temporal dithering and 16 primaries, the primary combination can be coded directly using K 4-bit primary indices or an index for the N selected primary combinations. For the second option, an additional N-element LUT is can be used to interpret the primary-combination index to K 4-bit primary indices. An implementation of combined spatial and temporal dithering as shown in
F1(x,y)=Pa and F2(x,y)=Pb, if x%2=0,
F1(x,y)=Pb and F2(x,y)=Pa, elsewhere. (9a)
The modulus operator % in Eq. 9a divides all vertical lines into two groups, all even lines and all odd lines, and the halftone output is vertically interleaved. Alternative rules for the 2× temporal dithering are horizontally interleaving and checkerboard-like interleaving, given by the following equations:
F1(x,y)=Pa and F2(x,y)=Pb, if y%2=0,
F1(x,y)=Pb and F2(x,y)=Pa, elsewhere. (9b)
and
F1(x,y)=Pa and F2(x,y)=Pb, if (x+y)%2=0,
F1(x,y)=Pb and F2(x,y)=Pa, elsewhere. (9c)
Further, certain implementations of the functionality of the present disclosure are sufficiently mathematically, computationally, or technically complex that application-specific hardware or one or more physical computing devices (utilizing appropriate executable instructions) may be necessary to perform the functionality, for example, due to the volume or complexity of the calculations involved or to provide results substantially in real-time. For example, in some implementations using a large number of primary colors (e.g., greater than 8 primary colors) and several temporal frames (e.g., greater than 3), the number of possible color combinations can be very large (e.g., hundreds, thousands, or more possible colors) and a physical computing device may be necessary to select the appropriate combinations of primary colors to be displayed from the large number of possible colors. Accordingly, various implementations of the methods described herein can be performed by a hardware processor included in the display device (for example, the processor 21, the driver controller 29, and/or the array driver 22 described below with reference to the display device of
The method 1600 includes identifying for a given image pixel K colors in a neighborhood of the input image pixel color, as shown in block 1610. The K colors are from a color palette including colors capable of being displayed by temporal dithering of the N primary colors in M temporal sub-frames. In various implementations, the identified K colors can form a polyhedron that includes the input image pixel color in a color space associated with the color palette. In various implementations, the polyhedron can be a tetrahedron.
The method 1600 further includes calculating weights for the identified K colors, as shown in block 1620. The weights are calculated such that a color combination produced by blending the K colors with the corresponding weights produces a color that is perceptually similar to the input image pixel color. In various implementations, calculating weights for the identified K colors can include calculating a volume of a sub-polyhedron (e.g., a sub-tetrahedron) that includes a face of the polyhedron (e.g., a tetrahedron) and a vertex corresponding to the input image pixel color.
The method 1600 further includes determining a display color from the color palette based at least in part on the calculated weights and a rank order given by a halftone screen for the given image pixel, as shown in block 1630. The halftone screen is associated with a block of the display elements of the display device. In various implementations, the halftone screen can be an array including L×L elements. In some implementations, the halftone screen can have different shapes, such as, for example, square, rectangle, hexagon, octagon, circle, etc. In various implementations, the halftone screen can provide the rank order of every display element in the display device and the color displayed by each display element is based upon the calculated weight and the rank order. In various implementations, determining the display color can include comparing the rank order for the given image pixel with a threshold value, the threshold value based at least in part on one or more of the weights.
The method 1600 further includes assigning the determined display color to a display element of the display device that corresponds to the image pixel, as shown in block 1640. In various implementations, the method can include identifying a set of primary colors that corresponds to the display color. The set of primary colors can be displayed in one of the M temporal sub-frames.
The method 1600 can be performed in its entirety by a physical computing device. The computing device can include a hardware processor and one or more buffers. A non-transitory computer readable storage medium can include instructions that can be executed by a processor in a physical computing device to perform the method 1600. In various implementations, the computing device and/or the non-transitory computer readable storage medium can be included with a system that includes a display device including a plurality of IMOD display elements including but not limited to implementations similar to AIMOD 900.
A region of the display device can be configured to display a color by using the method 1600 discussed above. The region of the display device can include at least two pixels. For example, each of the at least two pixels can be configured to display selected primary colors in different temporal sub-frames such that the region of the display device including the at least two pixels displays a blended color generated by temporal dithering. In various implementations, the at least two pixels include a first display pixel that can display a first primary color in a first temporal sub-frame and a second display pixel that can display a second primary color in the first temporal sub-frame. In a second temporal sub-frame, the first display pixel can display the second primary color while the second display pixel can display the first primary color, for example, as shown in
The display device 40 includes a housing 41, a display 30, an antenna 43, a speaker 45, an input device 48 and a microphone 46. The housing 41 can be formed from any of a variety of manufacturing processes, including injection molding, and vacuum forming. In addition, the housing 41 may be made from any of a variety of materials, including, but not limited to: plastic, metal, glass, rubber and ceramic, or a combination thereof. The housing 41 can include removable portions (not shown) that may be interchanged with other removable portions of different color, or containing different logos, pictures, or symbols.
The display 30 may be any of a variety of displays, including a bi-stable or analog display, as described herein. The display 30 also can be configured to include a flat-panel display, such as plasma, EL, OLED, STN LCD, or TFT LCD, or a non-flat-panel display, such as a CRT or other tube device. In addition, the display 30 can include an IMOD-based display, as described herein.
The components of the display device 40 are schematically illustrated in
The network interface 27 includes the antenna 43 and the transceiver 47 so that the display device 40 can communicate with one or more devices over a network. The network interface 27 also may have some processing capabilities to relieve, for example, data processing requirements of the processor 21. The antenna 43 can transmit and receive signals. In some implementations, the antenna 43 transmits and receives RF signals according to the IEEE 16.11 standard, including IEEE 16.11(a), (b), or (g), or the IEEE 802.11 standard, including IEEE 802.11a, b, g, n, and further implementations thereof. In some other implementations, the antenna 43 transmits and receives RF signals according to the Bluetooth® standard. In the case of a cellular telephone, the antenna 43 can be designed to receive code division multiple access (CDMA), frequency division multiple access (FDMA), time division multiple access (TDMA), Global System for Mobile communications (GSM), GSM/General Packet Radio Service (GPRS), Enhanced Data GSM Environment (EDGE), Terrestrial Trunked Radio (TETRA), Wideband-CDMA (W-CDMA), Evolution Data Optimized (EV-DO), NEV-DO, EV-DO Rev A, EV-DO Rev B, High Speed Packet Access (HSPA), High Speed Downlink Packet Access (HSDPA), High Speed Uplink Packet Access (HSUPA), Evolved High Speed Packet Access (HSPA+), Long Term Evolution (LTE), AMPS, or other known signals that are used to communicate within a wireless network, such as a system utilizing 3G, 4G or 5G technology. The transceiver 47 can pre-process the signals received from the antenna 43 so that they may be received by and further manipulated by the processor 21. The transceiver 47 also can process signals received from the processor 21 so that they may be transmitted from the display device 40 via the antenna 43.
In some implementations, the transceiver 47 can be replaced by a receiver. In addition, in some implementations, the network interface 27 can be replaced by an image source, which can store or generate image data to be sent to the processor 21. The processor 21 can control the overall operation of the display device 40. The processor 21 receives data, such as compressed image data from the network interface 27 or an image source, and processes the data into raw image data or into a format that can be readily processed into raw image data. The processor 21 can send the processed data to the driver controller 29 or to the frame buffer 28 for storage. Raw data typically refers to the information that identifies the image characteristics at each location within an image. For example, such image characteristics can include color, saturation and gray-scale level. The processor 21 (or other computing hardware in the device 40) can be programmed to perform implementations of the methods described herein such as the methods 1000, 1200 and 1600. The processor 21 (or other computing hardware in the device 40) can be in communication with a computer-readable medium that includes instructions, that when executed by the processor 21, cause the processor 21 to perform implementations of the methods described herein such as the methods 1000, 1200 and 1600.
The processor 21 can include a microcontroller, CPU, or logic unit to control operation of the display device 40. The conditioning hardware 52 may include amplifiers and filters for transmitting signals to the speaker 45, and for receiving signals from the microphone 46. The conditioning hardware 52 may be discrete components within the display device 40, or may be incorporated within the processor 21 or other components.
The driver controller 29 can take the raw image data generated by the processor 21 either directly from the processor 21 or from the frame buffer 28 and can re-format the raw image data appropriately for high speed transmission to the array driver 22. In some implementations, the driver controller 29 can re-format the raw image data into a data flow having a raster-like format, such that it has a time order suitable for scanning across the display array 30. Then the driver controller 29 sends the formatted information to the array driver 22. Although a driver controller 29, such as an LCD controller, is often associated with the system processor 21 as a stand-alone Integrated Circuit (IC), such controllers may be implemented in many ways. For example, controllers may be embedded in the processor 21 as hardware, embedded in the processor 21 as software, or fully integrated in hardware with the array driver 22.
The array driver 22 can receive the formatted information from the driver controller 29 and can re-format the video data into a parallel set of waveforms that are applied many times per second to the hundreds, and sometimes thousands (or more), of leads coming from the display's x-y matrix of display elements.
In some implementations, the driver controller 29, the array driver 22, and the display array 30 are appropriate for any of the types of displays described herein. For example, the driver controller 29 can be a conventional display controller or a bi-stable display controller (such as an IMOD display element controller). Additionally, the array driver 22 can be a conventional driver or a bi-stable display driver (such as an IMOD display element driver). Moreover, the display array 30 can be a conventional display array or a bi-stable display array (such as a display including an array of IMOD display elements). The driver controller 29 and/or the array driver 22 can be an AIMOD controller or driver. In some implementations, the driver controller 29 can be integrated with the array driver 22. Such an implementation can be useful in highly integrated systems, for example, mobile phones, portable-electronic devices, watches or small-area displays.
In some implementations, the input device 48 can be configured to allow, for example, a user to control the operation of the display device 40. The input device 48 can include a keypad, such as a QWERTY keyboard or a telephone keypad, a button, a switch, a rocker, a touch-sensitive screen, a touch-sensitive screen integrated with the display array 30, or a pressure- or heat-sensitive membrane. The microphone 46 can be configured as an input device for the display device 40. In some implementations, voice commands through the microphone 46 can be used for controlling operations of the display device 40.
The power supply 50 can include a variety of energy storage devices. For example, the power supply 50 can be a rechargeable battery, such as a nickel-cadmium battery or a lithium-ion battery. In implementations using a rechargeable battery, the rechargeable battery may be chargeable using power coming from, for example, a wall socket or a photovoltaic device or array. Alternatively, the rechargeable battery can be wirelessly chargeable. The power supply 50 also can be a renewable energy source, a capacitor, or a solar cell, including a plastic solar cell or solar-cell paint. The power supply 50 also can be configured to receive power from a wall outlet.
In some implementations, control programmability resides in the driver controller 29 which can be located in several places in the electronic display system. In some other implementations, control programmability resides in the array driver 22. The above-described methods for generating a constrained color palette may be implemented in any number of hardware and/or software components and in various configurations.
As used herein, a phrase referring to “at least one of” a list of items refers to any combination of those items, including single members. As an example, “at least one of: a, b, or c” is intended to cover: a, b, c, a-b, a-c, b-c, and a-b-c.
The various illustrative logics, logical blocks, modules, circuits and algorithm steps described in connection with the implementations disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. The interchangeability of hardware and software has been described generally, in terms of functionality, and illustrated in the various illustrative components, blocks, modules, circuits and steps described above. Whether such functionality is implemented in hardware or software depends upon the particular application and design constraints imposed on the overall system.
The hardware and data processing apparatus used to implement the various illustrative logics, logical blocks, modules and circuits described in connection with the aspects disclosed herein may be implemented or performed with a general purpose single- or multi-chip processor, a digital signal processor (DSP), an application specific integrated circuit (ASIC), a field programmable gate array (FPGA) or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to perform the functions described herein. A general purpose processor may be a microprocessor, or, any conventional processor, controller, microcontroller, or state machine. A processor also may be implemented as a combination of computing devices, such as a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration. In some implementations, particular steps and methods may be performed by circuitry that is specific to a given function.
In one or more aspects, the functions described may be implemented in hardware, digital electronic circuitry, computer software, firmware, including the structures disclosed in this specification and their structural equivalents thereof, or in any combination thereof. Implementations of the subject matter described in this specification also can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions, encoded on a computer storage media for execution by, or to control the operation of, data processing apparatus.
If implemented in software, the functions may be stored on or transmitted over as one or more instructions or code on a computer-readable medium. The steps of a method or algorithm disclosed herein may be implemented in a processor-executable software module which may reside on a computer-readable medium. Computer-readable media includes both computer storage media and communication media including any medium that can be enabled to transfer a computer program from one place to another. A storage media may be any available media that may be accessed by a computer. By way of example, and not limitation, such computer-readable media may include RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that may be used to store desired program code in the form of instructions or data structures and that may be accessed by a computer. Also, any connection can be properly termed a computer-readable medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk, and blu-ray disc where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above also may be included within the scope of computer-readable media. Additionally, the operations of a method or algorithm may reside as one or any combination or set of codes and instructions on a machine readable medium and computer-readable medium, which may be incorporated into a computer program product.
Various modifications to the implementations described in this disclosure may be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other implementations without departing from the spirit or scope of this disclosure. Thus, the claims are not intended to be limited to the implementations shown herein, but are to be accorded the widest scope consistent with this disclosure, the principles and the novel features disclosed herein. Additionally, a person having ordinary skill in the art will readily appreciate, the terms “upper” and “lower” are sometimes used for ease of describing the figures, and indicate relative positions corresponding to the orientation of the figure on a properly oriented page, and may not reflect the proper orientation of, e.g., an IMOD display element as implemented.
Certain features that are described in this specification in the context of separate implementations also can be implemented in combination in a single implementation. Conversely, various features that are described in the context of a single implementation also can be implemented in multiple implementations separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, a person having ordinary skill in the art will readily recognize that such operations need not be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. Further, the drawings may schematically depict one more example processes in the form of a flow diagram. However, other operations that are not depicted can be incorporated in the example processes that are schematically illustrated. For example, one or more additional operations can be performed before, after, simultaneously, or between any of the illustrated operations. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system components in the implementations described above should not be understood as requiring such separation in all implementations, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products. Additionally, other implementations are within the scope of the following claims. In some cases, the actions recited in the claims can be performed in a different order and still achieve desirable results.
This disclosure claims priority to U.S. Provisional Patent Application No. 61/893,759, filed Oct. 21, 2013, entitled “SPATIO-TEMPORAL VECTOR SCREENING FOR COLOR DISPLAY DEVICES,” and assigned to the assignee hereof. The disclosure of the prior application is considered part of, and is incorporated by reference in, this disclosure.
Number | Date | Country | |
---|---|---|---|
61893759 | Oct 2013 | US |