Organic light emitting diode (OLED) displays can experience uneven degradation due to variations in displayed content. Differences between the degradation rates for pixels of the OLED display can lead to undesirable effects such as color shift or burn-in. Compensation techniques can be applied to OLEDs to prolong the useful life of an OLED display by mitigating these undesirable effects. However, once introduced, these compensation techniques must thereafter always be used. Further, the compensation techniques significantly increase power consumption requirements. Accordingly, new techniques for displaying images on an OLED display to delay the onset of burn-in and other undesirable effects may be needed.
Various embodiments may be generally directed to techniques for generating pixel shifting patterns for organic light emitting diode (OLED) displays. Pixel usage data for the OLED display can be accumulated. Areas of the OLED display susceptible to burn-in damage can be identified based on the accumulated pixel usage data. A pixel shifting pattern can be generated based on the accumulated pixel image data and data relating to an image to be displayed. The pixel shifting pattern can be generated to avoid the areas identified as susceptible to burn-in damage. The pixel shifting pattern can be applied to the image to be displayed to generate modified image data. The modified image data can limit further damage to the OLED display and thereby delay the onset of undesirable burn-in effects.
Degradation in OLED displays can be characterized by the loss of luminance over time. The rate of this degradation can be different for each pixel since the large number of pixels used to form the display can be used unevenly based on the displayed content. Differences in the degradation rates for the pixels can accumulate over time and can lead to undesirable effects such as color shift or burn-in. These undesirable effects have prevented the wide adoption of OLEDs for computer displays.
Compensation techniques can be applied to OLEDs to prolong the useful life of an OLED display by mitigating the burn-in effect. These compensation techniques typically depend on knowledge of the content history displayed by the OLED display over time. Compensation techniques can visually reduce the effects of burn-in. However, many compensation techniques are computationally intensive and thereby cause a significant increase in power consumption. Further, once compensation techniques are implemented, the techniques must be continuously used to prevent any visual artifacts from showing up again. Therefore, it is desirable to delay the onset of burn-in in OLED displays and the introduction of compensation techniques for as long as possible to limit increased power compensation and the need to thereafter always use compensation techniques.
By introducing some kind of dithering in pixel position on the display, burn-in can be delayed. As an example, the displayed image on a screen can be translated one pixel at a time following specific patterns to implement pixel shifting. Different display manufacturers may choose different patterns for such pixel shifting.
Conventional pixel shifting methods generally apply a universal pixel shifting scheme to the display area as a whole in an attempt to evenly distribute the potential damage to extended neighboring areas over time. However, in practice, evenly distributing the potential damage is unlikely to result due to (1) uneven usage of pixels (e.g., for certain user interfaces (UIs)) and/or (2) the high likelihood that each pixel shifting step may not get even coverage due to unexpected events such as interruption of the system.
Various embodiments described herein provide pixel shifting techniques that can can delay the onset of pixel damage without introducing significant increases to power consumption. By implementing the pixel shifting techniques described herein, the onset of pixel burn-in can be delayed. Various embodiments provide pixel shifting techniques based on history awareness of prior usage so as to achieve optimal burn-in avoidance and to delay the need for compensation for any self-emitting display devices (e.g., an OLED display).
Various embodiments described herein provide pixel shifting techniques that: (a) introduce time dynamism into the pixel shifting schemes/patterns by supplementing a series of steps with time weighted factors; (b) use history-aware selective/partial pixel shifting algorithms that use the accumulated pixel usage history to guide the choice of the pixel shifting algorithm achieving space dynamism; and/or (c) allow for a per-region pixel shifting algorithm targeting concurrent use of different pixel shifting algorithms in different regions of the same display—with each algorithm being generated based on pixel usage history. By analyzing the accumulated pixel usage data, the areas with more extensive burn-in damage can be identified, thereby enabling dynamic changes to the pixel shifting pattern to avoid these regions. Further, by dividing the whole screen area into multiple region based on pixel usage characteristics, each region can be addressed with a different pixel shifting scheme to achieve better damage avoidance results.
With general reference to notations and nomenclature used herein, one or more portions of the detailed description which follows may be presented in terms of program procedures executed on a computer or network of computers. These procedural descriptions and representations are used by those skilled in the art to most effectively convey the substances of their work to others skilled in the art. A procedure is here, and generally, conceived to be a self-consistent sequence of operations leading to a desired result. These operations are those requiring physical manipulations of physical quantities. Usually, though not necessarily, these quantities take the form of electrical, magnetic, or optical signals capable of being stored, transferred, combined, compared, and otherwise manipulated. It proves convenient at times, principally for reasons of common usage, to refer to these signals as bits, values, elements, symbols, characters, terms, numbers, or the like. It should be noted, however, that all of these and similar terms are to be associated with the appropriate physical quantities and are merely convenient labels applied to those quantities.
Further, these manipulations are often referred to in terms, such as adding or comparing, which are commonly associated with mental operations performed by a human operator. However, no such capability of a human operator is necessary, or desirable in most cases, in any of the operations described herein that form part of one or more embodiments. Rather, these operations are machine operations. Useful machines for performing operations of various embodiments include general purpose digital computers as selectively activated or configured by a computer program stored within that is written in accordance with the teachings herein, and/or include apparatus specially constructed for the required purpose. Various embodiments also relate to apparatus or systems for performing these operations. These apparatuses may be specially constructed for the required purpose or may include a general-purpose computer. The required structure for a variety of these machines will be apparent from the description given.
Reference is now made to the drawings, wherein like reference numerals are used to refer to like elements throughout. In the following description, for purpose of explanation, numerous specific details are set forth in order to provide a thorough understanding thereof. It may be evident, however, that the novel embodiments can be practiced without these specific details. In other instances, well known structures and devices are shown in block diagram form in order to facilitate a description thereof. The intention is to cover all modification, equivalents, and alternatives within the scope of the claims.
The pixel shifting schemes illustrated in
In various embodiments described herein, historical data for content that has been displayed on an OLED screen or display is maintained or tracked. As an example, historical data for content that has been displayed by the OLEDs can be maintained in a device driver of a graphics processing unit (GPU) (e.g., in a notebook computer) and/or in a memory. In various other embodiments, this pixel usage history could be maintained directly by an Operating System (OS), or through extension middleware or applications provided by independent software vendors.
In various embodiments described herein, the historical data for content that has been displayed by the OLEDs can be exploited or used by a pixel history generation (PHG) algorithm. The PHG algorithm can analyze the tracked historical data to generate or update a damage signature (DS) that is representative of the damage that has be incurred by the OLED display. The PHG can make this damage signature available to the entity (e.g., notebook computer or handheld computer) implementing the history-aware pixel shifting (HAPS) algorithm.
In various embodiments, the damage signature can include a set of priority levels assigned to regions of an OLED display screen. The priority levels can be based on damage that has occurred to the regions. As an example, heavily aged pixels and/or regions can be assigned low priority levels to reduce future usage while less used pixels and/or regions can be assigned high priority levels to ensure increased future usage.
As an example, the historical pixel usage data can provide an indication as to which regions and/or pixels of an OLED display have been used more heavily and/or which regions and/or pixels have a longer age or period of use. The pixel usage data can further provide an indication of which pixels and/or regions are closer to reaching an age or use level that could result in burn-in or some other undesirable display effect. This age or use level can be used to set a usage threshold for a pixel and/or region that the pixel shifting techniques described herein can attempt to avoid. That is, techniques described herein provide for the selection and generation of pixel shifting schemes that can be based on historical usage data and current image data to minimize further damage to a display and/or minimize the likelihood of further aging certain regions and/or pixels of a display that may be close (e.g., in terms of age and/or usage time) to reaching a threshold usage level that corresponds to burn-in or some other undesirable display effect.
Further, the pattern 300 can specify the amount of time the image stays at each step/pixel position. As an example, the amount of time can be represented as a fraction of a frame rate of the display providing the image. As shown in
In various embodiments, pixel shifting patterns can be provided that incorporate two additional parameters: applicability and dynamism. Applicability, for example, can be regional or universal. Dynamism, for example, can be with respect to time or space. Based on the introduction of these two additional parameters to a pixel shifting scheme, four different pixel shifting scheme combinations can be provided: (1) universal, time dynamism in pixel shifting patterns; (2) universal, space dynamism in pixel shifting patterns; (3) per-region, time dynamism in pixel shifting patterns; and (4) per-region, space dynamism in pixel shifting patterns. Each of these schemes are described in further detail herein.
In various embodiments, universal time dynamism can be provided in a HAPS algorithm. As an example, such a scheme can include a time-weighted factor. The time-weighted factor can specify the amount of time an image will stay at each step during a pixel shifting process window. Universal, time dynamism in pixel shifting patterns can therefore involve dynamic time weighted factors for each steps.
In various embodiments, the time weighted factors 402 are not constant or fixed. Instead, the time weighted factors 402 can be varied based on the characteristics of the image to be shown and the pixel usage history. Over time, the statistical effect of the pixel shifting scheme specified by the pattern 400 can result in preferred coverage of certain spaces or location of a display, as well as over preferred portions of time. Accordingly, the pattern 400 can be adjusted so as to enable a way to influence future coverage in areas of the screen that are at a higher risk of burn-in.
As an example, for a relatively new display, minimum burn-in impact can be provided by adjusting the pixel shifting pattern 400 to ensure that the pixels used for shifting are spread over as wide an area of the display as possible. Accordingly, the value of time weighted factors 402 can be based on the image to be shown.
As another example, the pixel shifting algorithm that generates the pattern 400 can begin with time-weighted factor values 402 having the same value of “1” in each step 302. Over time, the time weighted factors 402 can be increased for steps 302 corresponding to the destination pixels with lower brightness values as less bright pixels have less burn-in risk.
As another example, the pixel shifting algorithm that generates the pattern 400 can begin with time-weighted factor values 402 having the same relatively high values (e.g., >“1”) in each step 302. Over time, the time weighted factors 402 can be decreased steps 302 corresponding to the destination pixels with higher brightness values as brighter pixels have higher risk of burn-in. Overall, the introduction of the time-weighted factors 402 can adjust the future usage of certain pixels which can be based on pixel usage data. Further,
As shown in
In contrast,
Overall,
Further, in various embodiments, a device OS and/or a display application can determine when to implement time and/or space dynamism in conjunction with a HAPS algorithm. Determining when to use time and/or space dynamism in conjunction with a HAPS algorithm can be based on heuristics resulting from analysis of a current image to be displayed. The heuristics can identify scenarios where some jerkiness in movement (e.g., caused by pixel shifting of an image) is acceptable, or where use of a HAPs algorithm may not compromise the goal of prioritized damage avoidance.
The use of time weighted factors for all steps of a pixel shifting pattern can determine the future usage of the pixels. As such, the time weighted factors can determine the usage pattern of the pixels. With a pixel shifting pattern that does not use time weighting factors, all steps of the pixel shifting pattern can be driven with the pixel value for an equal amount of time. As a result of this type of pixel shifting, the expected pixel usage pattern can resemble the distributions shown in
To avoid further coverage on the center pixels that have high brightness values and to achieve a future usage pattern that will resemble the distributions 616 and 618 shown in
Overall, by introducing the use of time weighted factors with a pixel shifting scheme, peak usage of certain pixels can be reduced. As a result of reducing peak usage, the time when peak usage reaches a burn-in threshold can be delayed.
Each of the orbits 702-708 can include multiple steps 710. For each step value 710 provided, a corresponding position of a center pixel of an image in a first direction (e.g., an x direction) 712 can be provided along with a corresponding position of a center pixel of an image in a second direction (e.g., a y direction) 714. The center pixel positions 712 and 714 can specify a pixel shift—that is, the next center position of the image using the center point specification in the x direction 712 and the y direction 714.
Further, the pattern 700 can specify the amount of time 716 the image stays at each step/pixel position. As an example, the amount of time 716 can be represented as a fraction of a frame rate of the display providing the image. As shown in
In various embodiments, for steps 710 of orbits 702-708 that are directed to pixel positions that are further away from a center of the display, relatively higher valued time weighted factors 718 can be used. Further, for steps 710 of orbits 702-708 that are directed to pixel positions that are closer to the center, relatively lower valued time weighted factors 718 can be used. Accordingly, for pixel positions near the center, the time weighted factors can be equal to or close to “1”. As the distances in the x and y directions from center increase (e.g., as Δx and Δy relative to a center position increase), the time weighted factors 718 can increase and reach a maximum. By using the time weighted factors 718 in this manner, a usage distribution pattern of the pixels can become smoothed out like the distributions 616 and 618 shown in
The distributions 816 and 818 shown further improvement over the distributions 812 and 814 by biasing the time weighted factors appropriately. Specifically, the distributions 816 and 818 can be biased such that pixel shifting steps that involve the left side of the display where usage is relatively high can get less coverage and pixel shifting steps that involve the right side of the display where usage is relatively low can get increased coverage. In doing so, the non-symmetric usage distribution along the x-direction can be further improved or even cancelled out (compare distribution 812 to distribution 816).
The pixel shifting examples illustrated in
As an OLED screen or display continues to be used, uneven usage of the pixels can develop. The techniques described herein can respond by combining a pixel shifting scheme with time weighted factors to provide flexibility in the pixel shifting scheme to avoid potential burn-in damage by using the knowledge of existing accumulated pixel usage data/history. Adjustments to the time weighted factors can be accomplished by relying on the damage signature. As mentioned above, the damage signature for a display can specify priority levels for certain pixels and/or areas of the display. Time weighted factors can then be selected and modified over time based on updates to these priority levels while also being adjusted based on the current image to be shown.
Overall, the techniques described herein can be used to generate a pixel shifting scheme that accounts for accumulated usage data/history of the pixels formed by the OLED display and the characteristics of the image to be displayed (e.g., symmetric or non-symmetric) to reduce usage of areas at higher risk of burn-in and increase usage of areas with lower risk of burn-in, thereby delaying the onset of burn-in for the OLED display.
At 902, pixel usage data is accumulated. The pixel usage data can be usage data for pixels of an OLED display. The pixel usage data can include a history of the usage of each pixel of the OLED display over time based on the images displayed by the OLED display. The accumulated pixel usage data can be stored in a memory. The accumulated pixel usage data can be maintained by an OS, an application, or a dedicated display driver or software system. The accumulated pixel usage data can include an amount of time each pixel has been used and/or can include an age profile for each pixel.
In various embodiments the accumulated pixel usage data can be based on prior displayed images or content, can indicate an age of each pixel or region of the OLED display, can indicate a total amount of use of each pixel of the OLED display, can indicate a luminance level of each pixel of the OLED display, and/or can indicate a brightness level of each pixel of the OLED display.
At 904, the existing accumulated pixel usage data from step 902 can be analyzed. The analysis can determine which pixels and/or portions of the OLED display have been used heavily and which pixels and/or portions of the OLED display have been used less heavily. Further, the analysis can provide an indication as to which pixels and/or regions of the OLED display are close to experiencing burn-in, have a high risk of experiencing burn-in, and/or currently experience burn-in. The analysis can provide a damage signature for the OLED display. As an example, the analysis can generate a damage signature that can comprise a set of priority levels assigned to regions or pixels of the OLED display with heavily aged pixels/regions being assigned low priority (for low future usage) and less used pixels/regions being assigned high priority (for increased usage). Overall, the analysis at 904 can provide an assessment of which pixels/regions of an OLED display should be attempted to be used more and which pixels/regions should be attempted to be used less in order to delay the onset of burn-in or other damage to the OLED display. A usage profile for each pixel or region of the OLED display can be generated based on the accumulated pixel usage data. The usage profile can include any of the information described herein including a damage profile and/or any information indicating an age, brightness level, luminance level, or proximity in terms of use or age to a burn-in threshold for any pixel or region of the OLED display.
At 906, image data can be received. The image data can represent information for displaying a current image on the OLED display. The image to be displayed can be a symmetric or non-symmetric or asymmetric image. The image data can be for any image to be displayed.
At 908, the image data can be analyzed. The image data can be analyzed to determine how pixels are to be used to display the image. In various embodiments, the analysis can determine a pixel usage distribution for the image data by assuming no pixel shifting is to be used in displaying the image. By doing so, the analysis at 908 can provide an indication as to what pixels and/or regions of the OLED display will be impacted by displaying the image data.
At 910, a pixel shifting scheme can be selected and/or generated. The pixel shifting scheme can be selected and/or generated based on the accumulated pixel usage data and the analysis thereof along with the image data and the analysis thereof. In various embodiments, the pixel shifting scheme can be selected based on the damage signature of the OLED display, the historical pixel usage of the OLED display (e.g., the age profile of the pixels), and/or the content of the image to be displayed. The pixel shifting scheme can include a sequence of steps forming one or more image shifting orbits. The sequence of steps can specify shifts of the image relative to a center of the image. That is, each step can specify a location to display the image on the OLED display relative to a center of the image. The specified locations can be pixel positions of the OLED display. These specified locations can include a horizontal (or x-axis) positional indicator and a vertical (or y-axis) positional indicator.
The pixel shifting scheme can specify an amount of time corresponding to each positional shift of the image. Further, the pixel shifting scheme can include time and/or space dynamism. In various embodiments, the pixel shifting scheme can provide time and/or space weighted factors such that certain positional shifts are used or skipped and amounts of time at certain positions are longer than amounts of time at certain other positions. The pixel shifting scheme can be optimized based on the accumulated usage data and current image data to delay the onset of burn-in by, for example, favoring less used pixels/regions in comparison to more heavily used pixels/regions.
At 912 the selected pixel shifting scheme can be applied to the current image. The pixel shifting scheme can be used to adjust the pixel usage for displaying the image. As an example, the pixel shifting scheme can ensure the image is displayed with high quality while minimizing the risk of burn in by using more pixel/regions having less usage over time and using fewer pixel/regions having more usage over time. Applying the generated pixel shifting pattern to the image data of the image can generate modified image data. The modified image data can represent data for displaying the image according to the pixel shifting pattern.
At 914, the modified image data can be provided for display. The modified image data after undergoing pixel shifting can be provided to an OLED display for rendering the image. That is, the modified image data can be outputted for display on an OLED display such that the image is displayed according to the pixel shifting pattern applied.
The logic flow 900 can be implemented by any of the devices described herein and can be implanted in hardware, software, or any combination thereof.
Various embodiments and techniques are described herein in relation to OLED displays but are not so limited. The embodiments and techniques described herein can be applied to any self-emissive and/or pixel-based displays including, for example, plasma displays, micro LED displays, and quantum dot LED (QLED) displays as well as liquid crystal displays (LCDs).
At 1002, pixel usage data can be reviewed. As example, the pixel usage data can be read from a memory.
At 1004, an initial pixel shifting scheme can be selected. As an example, the initial pixel shifting scheme can be a pixel shifting scheme that does not include any space or time dynamism. That is, the initial pixel shifting scheme can specify positional steps and times having all equal weights. This initial pixel shifting scheme can be a baseline pixel shifting scheme and can be considered to be an initial preferred pixel shifting scheme.
At 1006, an alternative pixel shifting scheme can be selected. The alternative pixel shifting scheme can be include space and/or time dynamism. As an example, the alternative pixel shifting scheme can include time weighted factors and/or positional weighted factors. The alternative pixel shifting scheme can be selected from a group of alternative pixel shifting schemes.
At 1008, a pixel usage pattern based on the alternative pixel shifting scheme can be calculated.
At 1010, a comparison of the pixel usage pattern derived in 1008 can be compared to the expected pixel usage pattern for the initial or baseline pixel usage pattern from 1004. As an example, the resulting pixel usage patterns for a given image can be determined based on the initial and alternative pixel shifting schemes. A determination can then be made from the predicted patterns which pixel shifting scheme will likely result in best delaying the onset of burn-in, prevent further damage to an OLED display, and/or best distribute usage of pixels while maintaining a desired image display quality. Other metrics can be used for comparing the predicted usage patterns to determine which usage pattern is preferred. As an example, a pixel shifting pattern can be chosen base don its ability to introduce the less additional damage to a display or to age certain pixels and/or regions of the display the least amount.
If the initial pixel shifting scheme is determined to be preferred over the alternative pixel shifting scheme, then the logic flow can progress to 1012. At 1012, a process for selecting a next alternative pixel shifting scheme can be implemented. After 1012, operations shown in 1006, 1008, and 1010 can be repeated to compare a next pixel shifting scheme to the initially selected baseline pixel shifting scheme.
If the initial pixel shifting scheme is determined not to be preferred (e.g., the alternative pixel shifting scheme is determined to be preferred), then the logic flow can progress to 1014. At 1014, it can be determined if any additional alternative pixel shifting schemes are available for evaluation. If additional pixel shifting schemes are available, the logic flow can progress to 1012. If no additional pixel shifting schemes are available, the logic flow can progress to 1016. Operations 1014 and 1012 can ensure that all schemes are evaluated and compared to a current preferred scheme before making a final decisions as to what pixel shifting scheme to use. In this way, an optimal pixel shifting scheme can be selected.
At 1016, the current pixel shifting scheme determined to be preferred in 1010 can be replaced and/or updated with the pixel shifting scheme determined to be preferred in 1010.
At 1018, the selected pixel shifting scheme can be applied. The selected pixel shifting scheme can be applied to a current image to be displayed.
Techniques described herein can also provide for a display area of an OLED display to be divided or parsed into multiple segments or partitions. Each segment can have distinct usage characteristics. For example, an OLED display that is used to display an user interface for an OS can have certain segments that are relatively static (e.g., that display the same images repeatedly or constantly) while other segments can vary more frequently (e.g., that consistently display different images). Accumulated historical data of pixel usage can reveal these different multiple usage segments of an OLED display and can be used to determine the differently used segments of an OLED display. Further, techniques described herein can be used to apply different pixel shifting schemes to each separately identified segment.
In various embodiments, various HAPS algorithms for pixel shifting can be applied to the segments 1102, 1104, and 1106. As an example, a pixel shifting scheme for segment 1104 can be used that is biased to provide more coverage and use along a horizontal direction. For segment 1106, a pixel shifting scheme can be used that is biased to provide more coverage along a vertical direction. For segment 1102, a pixel shifting scheme can be used that provides for shifts evenly along all directions while avoiding certain areas that are at high risk for burn-in if necessary. Such per-region time/space dynamism HAPS could potentially achieve optimal performance to avoid burn-in.
As used in this application, the terms “system” and “component” and “module” are intended to refer to a computer-related entity, either hardware, a combination of hardware and software, software, or software in execution, examples of which are provided by the exemplary computing architecture 1300. For example, a component can be, but is not limited to being, a process running on a processor, a processor, a hard disk drive, multiple storage drives (of optical and/or magnetic storage medium), an object, an executable, a thread of execution, a program, and/or a computer. By way of illustration, both an application running on a server and the server can be a component. One or more components can reside within a process and/or thread of execution, and a component can be localized on one computer and/or distributed between two or more computers. Further, components may be communicatively coupled to each other by various types of communications media to coordinate operations. The coordination may involve the uni-directional or bi-directional exchange of information. For instance, the components may communicate information in the form of signals communicated over the communications media. The information can be implemented as signals allocated to various signal lines. In such allocations, each message is a signal. Further embodiments, however, may alternatively employ data messages. Such data messages may be sent across various connections. Exemplary connections include parallel interfaces, serial interfaces, and bus interfaces.
The computing architecture 1300 includes various common computing elements, such as one or more processors, multi-core processors, co-processors, memory units, chipsets, controllers, peripherals, interfaces, oscillators, timing devices, video cards, audio cards, multimedia input/output (I/O) components, power supplies, and so forth. The embodiments, however, are not limited to implementation by the computing architecture 1300.
As shown in
The system bus 1308 provides an interface for system components including, but not limited to, the system memory 1306 to the processing unit 1304. The system bus 1308 can be any of several types of bus structure that may further interconnect to a memory bus (with or without a memory controller), a peripheral bus, and a local bus using any of a variety of commercially available bus architectures. Interface adapters may connect to the system bus 1308 via a slot architecture. Example slot architectures may include without limitation Accelerated Graphics Port (AGP), Card Bus, (Extended) Industry Standard Architecture ((E)ISA), Micro Channel Architecture (MCA), NuBus, Peripheral Component Interconnect (Extended) (PCI(X)), PCI Express, Personal Computer Memory Card International Association (PCMCIA), and the like.
The system memory 1306 may include various types of computer-readable storage media in the form of one or more higher speed memory units, such as read-only memory (ROM), random-access memory (RAM), dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory (e.g., one or more flash arrays), polymer memory such as ferroelectric polymer memory, ovonic memory, phase change or ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, an array of devices such as Redundant Array of Independent Disks (RAID) drives, solid state memory devices (e.g., USB memory, solid state drives (SSD) and any other type of storage media suitable for storing information. In the illustrated embodiment shown in
The computer 1302 may include various types of computer-readable storage media in the form of one or more lower speed memory units, including an internal (or external) hard disk drive (HDD) 1314, a magnetic floppy disk drive (FDD) 1316 to read from or write to a removable magnetic disk 1318, and an optical disk drive 1320 to read from or write to a removable optical disk 1322 (e.g., a CD-ROM or DVD). The HDD 1314, FDD 1316 and optical disk drive 1320 can be connected to the system bus 1308 by a HDD interface 1324, an FDD interface 1326 and an optical drive interface 1328, respectively. The HDD interface 1324 for external drive implementations can include at least one or both of Universal Serial Bus (USB) and IEEE 994 interface technologies.
The drives and associated computer-readable media provide volatile and/or nonvolatile storage of data, data structures, computer-executable instructions, and so forth. For example, a number of program modules can be stored in the drives and memory units 1310, 1312, including an operating system 1330, one or more application programs 1332, other program modules 1334, and program data 1336. In one embodiment, the one or more application programs 1332, other program modules 1334, and program data 1336 can include, for example, the various applications and/or components of the computer-mediated reality system 100.
A user can enter commands and information into the computer 1302 through one or more wire/wireless input devices, for example, a keyboard 1338 and a pointing device, such as a mouse 1340. Other input devices may include microphones, infra-red (IR) remote controls, radio-frequency (RF) remote controls, game pads, stylus pens, card readers, dongles, finger print readers, gloves, graphics tablets, joysticks, keyboards, retina readers, touch screens (e.g., capacitive, resistive, etc.), trackballs, trackpads, sensors, styluses, and the like. These and other input devices are often connected to the processing unit 1304 through an input device interface 1342 that is coupled to the system bus 1308, but can be connected by other interfaces such as a parallel port, IEEE 994 serial port, a game port, a USB port, an IR interface, and so forth.
A monitor 1344 or other type of display device is also connected to the system bus 1308 via an interface, such as a video adaptor 1346. The monitor 1344 may be internal or external to the computer 1302. In addition to the monitor 1344, a computer typically includes other peripheral output devices, such as speakers, printers, and so forth.
The computer 1302 may operate in a networked environment using logical connections via wire and/or wireless communications to one or more remote computers, such as a remote computer 1348. The remote computer 1348 can be a workstation, a server computer, a router, a personal computer, portable computer, microprocessor-based entertainment appliance, a peer device or other common network node, and typically includes many or all of the elements described relative to the computer 1302, although, for purposes of brevity, only a memory/storage device 1350 is illustrated. The logical connections depicted include wire/wireless connectivity to a local area network (LAN) 1352 and/or larger networks, for example, a wide area network (WAN) 1354. Such LAN and WAN networking environments are commonplace in offices and companies, and facilitate enterprise-wide computer networks, such as intranets, all of which may connect to a global communications network, for example, the Internet.
When used in a LAN networking environment, the computer 1302 is connected to the LAN 1352 through a wire and/or wireless communication network interface or adaptor 1356. The adaptor 1356 can facilitate wire and/or wireless communications to the LAN 1352, which may also include a wireless access point disposed thereon for communicating with the wireless functionality of the adaptor 1356.
When used in a WAN networking environment, the computer 1302 can include a modem 1358, or is connected to a communications server on the WAN 1354, or has other means for establishing communications over the WAN 1354, such as by way of the Internet. The modem 1358, which can be internal or external and a wire and/or wireless device, connects to the system bus 1308 via the input device interface 1342. In a networked environment, program modules depicted relative to the computer 1302, or portions thereof, can be stored in the remote memory/storage device 1350. It will be appreciated that the network connections shown are exemplary and other means of establishing a communications link between the computers can be used.
The computer 1302 is operable to communicate with wire and wireless devices or entities using the IEEE 802 family of standards, such as wireless devices operatively disposed in wireless communication (e.g., IEEE 802.16 over-the-air modulation techniques). This includes at least Wi-Fi (or Wireless Fidelity), WiMax, and Bluetooth™ wireless technologies, among others. Thus, the communication can be a predefined structure as with a conventional network or simply an ad hoc communication between at least two devices. Wi-Fi networks use radio technologies called IEEE 802.11x (a, b, g, n, etc.) to provide secure, reliable, fast wireless connectivity. A Wi-Fi network can be used to connect computers to each other, to the Internet, and to wire networks (which use IEEE 802.3-related media and functions).
As shown in
The clients 1402 and the servers 1404 may communicate information between each other using a communication framework 1406. The communications framework 1406 may implement any well-known communications techniques and protocols. The communications framework 1406 may be implemented as a packet-switched network (e.g., public networks such as the Internet, private networks such as an enterprise intranet, and so forth), a circuit-switched network (e.g., the public switched telephone network), or a combination of a packet-switched network and a circuit-switched network (with suitable gateways and translators).
The communications framework 1406 may implement various network interfaces arranged to accept, communicate, and connect to a communications network. A network interface may be regarded as a specialized form of an input output interface. Network interfaces may employ connection protocols including without limitation direct connect, Ethernet (e.g., thick, thin, twisted pair 10/100/1900 Base T, and the like), token ring, wireless network interfaces, cellular network interfaces, IEEE 802.11a-x network interfaces, IEEE 802.16 network interfaces, IEEE 802.20 network interfaces, and the like. Further, multiple network interfaces may be used to engage with various communications network types. For example, multiple network interfaces may be employed to allow for the communication over broadcast, multicast, and unicast networks. Should processing requirements dictate a greater amount speed and capacity, distributed network controller architectures may similarly be employed to pool, load balance, and otherwise increase the communicative bandwidth required by clients 1402 and the servers 1404. A communications network may be any one and the combination of wired and/or wireless networks including without limitation a direct interconnection, a secured custom connection, a private network (e.g., an enterprise intranet), a public network (e.g., the Internet), a Personal Area Network (PAN), a Local Area Network (LAN), a Metropolitan Area Network (MAN), an Operating Missions as Nodes on the Internet (OMNI), a Wide Area Network (WAN), a wireless network, a cellular network, and other communications networks.
Various embodiments may be implemented using hardware elements, software elements, or a combination of both. Examples of hardware elements may include processors, microprocessors, circuits, circuit elements (e.g., transistors, resistors, capacitors, inductors, and so forth), integrated circuits, application specific integrated circuits (ASIC), programmable logic devices (PLD), digital signal processors (DSP), field programmable gate array (FPGA), logic gates, registers, semiconductor device, chips, microchips, chip sets, and so forth. Examples of software may include software components, programs, applications, computer programs, application programs, system programs, machine programs, operating system software, middleware, firmware, software modules, routines, subroutines, functions, methods, procedures, software interfaces, application program interfaces (API), instruction sets, computing code, computer code, code segments, computer code segments, words, values, symbols, or any combination thereof. Determining whether an embodiment is implemented using hardware elements and/or software elements may vary in accordance with any number of factors, such as desired computational rate, power levels, heat tolerances, processing cycle budget, input data rates, output data rates, memory resources, data bus speeds and other design or performance constraints.
One or more aspects of at least one embodiment may be implemented by representative instructions stored on a machine-readable medium which represents various logic within the processor, which when read by a machine causes the machine to fabricate logic to perform the techniques described herein. Such representations, known as “IP cores” may be stored on a tangible, machine readable medium and supplied to various customers or manufacturing facilities to load into the fabrication machines that actually make the logic or processor. Some embodiments may be implemented, for example, using a machine-readable medium or article which may store an instruction or a set of instructions that, if executed by a machine, may cause the machine to perform a method and/or operations in accordance with the embodiments. Such a machine may include, for example, any suitable processing platform, computing platform, computing device, processing device, computing system, processing system, computer, processor, or the like, and may be implemented using any suitable combination of hardware and/or software. The machine-readable medium or article may include, for example, any suitable type of memory unit, memory device, memory article, memory medium, storage device, storage article, storage medium and/or storage unit, for example, memory, removable or non-removable media, erasable or non-erasable media, writeable or re-writeable media, digital or analog media, hard disk, floppy disk, Compact Disk Read Only Memory (CD-ROM), Compact Disk Recordable (CD-R), Compact Disk Rewriteable (CD-RW), optical disk, magnetic media, magneto-optical media, removable memory cards or disks, various types of Digital Versatile Disk (DVD), a tape, a cassette, or the like. The instructions may include any suitable type of code, such as source code, compiled code, interpreted code, executable code, static code, dynamic code, encrypted code, and the like, implemented using any suitable high-level, low-level, object-oriented, visual, compiled and/or interpreted programming language.
The following examples pertain to further embodiments, from which numerous permutations and configurations will be apparent.
Example 1 is an apparatus comprising a memory and logic, at least a portion of the logic implemented in circuitry coupled to the memory, the logic to accumulate pixel usage data for an organic light emitting diode (OLED) display to store in the memory, receive image data for an image to be displayed, generate a pixel shifting pattern for the image based on the accumulated pixel usage data and the image data for the image, apply the pixel shifting pattern to the image to generate modified image data, and output the modified image data for display.
Example 2 is an extension of Example 1 or any other example disclosed herein, the accumulated pixel usage data based on prior displayed images.
Example 3 is an extension of Example 1 or any other example disclosed herein, the accumulated pixel usage data indicating an age of each pixel of the OLED display.
Example 4 is an extension of Example 1 or any other example disclosed herein, the accumulated pixel usage data indicating a total amount of use of each pixel of the OLED display.
Example 5 is an extension of Example 1 or any other example disclosed herein, the accumulated pixel usage data indicating a luminance level of each pixel of the OLED display.
Example 6 is an extension of Example 1 or any other example disclosed herein, the accumulated pixel usage data indicating a brightness level of each pixel of the OLED display.
Example 7 is an extension of Example 1 or any other example disclosed herein, the logic to generate a usage profile for each pixel of the OLED display based on the accumulated pixel usage data.
Example 8 is an extension of Example 7 or any other example disclosed herein, the usage profile to include a damage signature for the OLED display.
Example 9 is an extension of Example 8 or any other example disclosed herein, the damage signature to indicate a level of damage incurred by one or more regions of the OLED display.
Example 10 is an extension of Example 9 or any other example disclosed herein, the level of damage specified by a priority level assigned to each region of the OLED display.
Example 11 is an extension of Example 10 or any other example disclosed herein, the logic to assign a relatively low priority level to regions with relatively high damage and to assign a relatively high priority level to regions with relatively low damage.
Example 12 is an extension of Example 10 or any other example disclosed herein, the logic to assign a relatively low priority level to regions characterized by relatively high aging and to assign a relatively high priority level to regions characterized by relatively low aging.
Example 13 is an extension of Example 10 or any other example disclosed herein, the logic to assign a relatively low priority level to regions characterized by relatively higher brightness and to assign a relatively high priority level to regions characterized by relatively lower brightness.
Example 14 is an extension of Example 1 or any other example disclosed herein, the pixel shifting pattern to include a number of steps, each step specifying a location to display the image on the OLED display relative to a center of the image and a corresponding amount of time the image is to occupy the specified location.
Example 15 is an extension of Example 14 or any other example disclosed herein, the location specified by a horizontal pixel position and a vertical pixel position.
Example 16 is an extension of Example 14 or any other example disclosed herein, the amount of time indicated by a fraction of a frame rate of the OLED display.
Example 17 is an extension of Example 14 or any other example disclosed herein, the pixel shifting pattern to include one or more of an adjustment to the amount of time and an adjustment to the specified location based on the accumulated pixel usage data and the image data of the image.
Example 18 is an extension of Example 14 or any other example disclosed herein, the pixel shifting pattern to include a time weighted factor to adjust the amount of time the image is to occupy the specified location.
Example 19 is an extension of Example 18 or any other example disclosed herein, the time weighted factor to be set to zero to indicate a specified location is to be skipped.
Example 20 is an extension of Example 14 or any other example disclosed herein, the logic to modify the pixel shifting pattern periodically.
Example 21 is an extension of Example 14 or any other example disclosed herein, the logic to parse the OLED display into two or more non-overlapping segments based on the accumulated pixel usage data.
Example 22 is an extension of Example 21 or any other example disclosed herein, the logic to generate different pixel shifting patterns for each non-overlapping segment.
Example 23 is an extension of Example 1 or any other example disclosed herein, the pixel shifting pattern to delay an onset of burn-in for the OLED display.
Example 24 is a method comprising accumulating pixel usage data for an organic light emitting diode (OLED) display, receiving image data for an image to be displayed, generating a pixel shifting pattern for the image based on the accumulated pixel usage data and the image data for the image, applying the pixel shifting pattern to the image to generate modified image data, and outputting the modified image data for display.
Example 25 is an extension of Example 24 or any other example disclosed herein, the pixel usage data based on prior displayed images.
Example 26 is an extension of Example 24 or any other example disclosed herein, the pixel usage data indicating an age of each pixel of the OLED display.
Example 27 is an extension of Example 24 or any other example disclosed herein, the pixel usage data indicating a total amount of use of each pixel of the OLED display.
Example 28 is an extension of Example 24 or any other example disclosed herein, the pixel usage data indicating a luminance level of each pixel of the OLED display.
Example 29 is an extension of Example 24 or any other example disclosed herein, the pixel usage data indicating a brightness level of each pixel of the OLED display.
Example 30 is an extension of Example 24 or any other example disclosed herein, generating a usage profile for each pixel of the OLED display based on the pixel usage data.
Example 31 is an extension of Example 30 or any other example disclosed herein, including a damage signature for the OLED display in the usage profile.
Example 32 is an extension of Example 2314 or any other example disclosed herein, indicating a level of damage incurred by one or more regions of the OLED display in the damage profile.
Example 33 is an extension of Example 32 or any other example disclosed herein, indicating the level of damage by specifying a priority level assigned to each region of the OLED display.
Example 34 is an extension of Example 33 or any other example disclosed herein, assigning a relatively low priority level to regions with relatively high damage and assigning a relatively high priority level to regions with relatively low damage.
Example 35 is an extension of Example 33 or any other example disclosed herein, assigning a relatively low priority level to regions characterized by relatively high aging and assigning a relatively high priority level to regions characterized by relatively low aging.
Example 36 is an extension of Example 33 or any other example disclosed herein, assigning a relatively low priority level to regions characterized by relatively higher brightness and assigning a relatively high priority level to regions characterized by relatively lower brightness.
Example 37 is an extension of Example 24 or any other example disclosed herein, the pixel shifting pattern to include a number of steps, each step specifying a location to display the image on the OLED display relative to a center of the image and a corresponding amount of time the image is to occupy the specified location.
Example 38 is an extension of Example 37 or any other example disclosed herein, specifying the location by a horizontal pixel position and a vertical pixel position.
Example 39 is an extension of Example 37 or any other example disclosed herein, indicating the amount of time by a fraction of a frame rate of the OLED display.
Example 40 is an extension of Example 37 or any other example disclosed herein, the pixel shifting pattern to include one or more of an adjustment to the amount of time and an adjustment to the specified location based on the accumulated pixel usage data and the image data of the image.
Example 41 is an extension of Example 37 or any other example disclosed herein, the pixel shifting pattern to include a time weighted factor to adjust the amount of time the image is to occupy the specified location.
Example 42 is an extension of Example 41 or any other example disclosed herein, setting the time weighted factor to be zero to indicate a specified location is to be skipped.
Example 43 is an extension of Example 37 or any other example disclosed herein, modifying the pixel shifting pattern periodically.
Example 44 is an extension of Example 37 or any other example disclosed herein, parsing the OLED display into two or more non-overlapping segments based on the accumulated pixel usage data.
Example 45 is an extension of Example 44 or any other example disclosed herein, generating different pixel shifting patterns for each non-overlapping segment.
Example 46 is an extension of Example 24 or any other example disclosed herein, the pixel shifting pattern to delay an onset of burn-in for the OLED display.
Example 47 is at least one non-transitory computer-readable storage medium comprising a set of instructions that, in response to being executed on a computing device, cause the computing device to accumulate pixel usage data for an organic light emitting diode (OLED) display to store in the memory, receive image data for an image to be displayed, generate a pixel shifting pattern for the image based on the accumulated pixel usage data and the image data for the image, apply the pixel shifting pattern to the image to generate modified image data, and output the modified image data for display.
Example 48 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to accumulate pixel usage data based on prior displayed images.
Example 49 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to accumulate pixel usage data indicating an age of each pixel of the OLED display.
Example 50 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to accumulate pixel usage data indicating a total amount of use of each pixel of the OLED display.
Example 51 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to accumulate pixel usage data indicating a luminance level of each pixel of the OLED display.
Example 52 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to accumulate pixel usage data indicating a brightness level of each pixel of the OLED display.
Example 53 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate a usage profile for each pixel of the OLED display based on the accumulated pixel usage data.
Example 54 is an extension of Example 54 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate the usage profile to include a damage signature for the OLED display.
Example 55 is an extension of Example 54 or any other example disclosed herein, cause the computing device to include the damage signature to indicate a level of damage incurred by one or more regions of the OLED display.
Example 56 is an extension of Example 55 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to specify the level of damage by a priority level assigned to each region of the OLED display.
Example 57 is an extension of Example 56 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to assign a relatively low priority level to regions with relatively high damage and to assign a relatively high priority level to regions with relatively low damage.
Example 58 is an extension of Example 56 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to assign a relatively low priority level to regions characterized by relatively high aging and to assign a relatively high priority level to regions characterized by relatively low aging.
Example 59 is an extension of Example 56 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to assign a relatively low priority level to regions characterized by relatively higher brightness and to assign a relatively high priority level to regions characterized by relatively lower brightness.
Example 60 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate the pixel shifting pattern to include a number of steps, each step specifying a location to display the image on the OLED display relative to a center of the image and a corresponding amount of time the image is to occupy the specified location.
Example 61 is an extension of Example 60 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to specify the location by a horizontal pixel position and a vertical pixel position.
Example 62 is an extension of Example 60 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to indicate the amount of time by a fraction of a frame rate of the OLED display.
Example 63 is an extension of Example 60 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate the pixel shifting pattern to include one or more of an adjustment to the amount of time and an adjustment to the specified location based on the accumulated pixel usage data and the image data of the image.
Example 64 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate the pixel shifting pattern to include a time weighted factor to adjust the amount of time the image is to occupy the specified location.
Example 65 is an extension of Example 64 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to set the time weighted factor to be zero to indicate a specified location is to be skipped.
Example 66 is an extension of Example 60 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to modify the pixel shifting pattern periodically.
Example 67 is an extension of Example 60 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to parse the OLED display into two or more non-overlapping segments based on the accumulated pixel usage data.
Example 68 is an extension of Example 67 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate different pixel shifting patterns for each non-overlapping segment.
Example 69 is an extension of Example 47 or any other example disclosed herein, comprising instructions that, in response to being executed on the computing device, cause the computing device to generate the pixel shifting pattern to delay an onset of burn-in for the OLED display.
Each of the foregoing examples can be extended to any self-emissive and/or pixel-based display including, for example, plasma displays, micro LED displays, and quantum dot LED (QLED) displays as well as liquid crystal displays (LCDs).
The foregoing description of example embodiments has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit the present disclosure to the precise forms disclosed. Many modifications and variations are possible in light of this disclosure. It is intended that the scope of the present disclosure be limited not by this detailed description, but rather by the claims appended hereto. Future filed applications claiming priority to this application may claim the disclosed subject matter in a different manner, and may generally include any set of one or more limitations as variously disclosed or otherwise demonstrated herein.
Numerous specific details have been set forth herein to provide a thorough understanding of the embodiments. It will be understood by those skilled in the art, however, that the embodiments may be practiced without these specific details. In other instances, well-known operations, components, and circuits have not been described in detail so as not to obscure the embodiments. It can be appreciated that the specific structural and functional details disclosed herein may be representative and do not necessarily limit the scope of the embodiments.
Some embodiments may be described using the expression “coupled” and “connected” along with their derivatives. These terms are not intended as synonyms for each other. For example, some embodiments may be described using the terms “connected” and/or “coupled” to indicate that two or more elements are in direct physical or electrical contact with each other. The term “coupled,” however, may also mean that two or more elements are not in direct contact with each other, but yet still co-operate or interact with each other.
Unless specifically stated otherwise, it may be appreciated that terms such as “processing,” “computing,” “calculating,” “determining,” or the like, refer to the action and/or processes of a computer or computing system, or similar electronic computing device, that manipulates and/or transforms data represented as physical quantities (e.g., electronic) within the computing system's registers and/or memories into other data similarly represented as physical quantities within the computing system's memories, registers or other such information storage, transmission or display devices. The embodiments are not limited in this context.
It should be noted that the methods described herein do not have to be executed in the order described, or in any particular order. Moreover, various activities described with respect to the methods identified herein can be executed in serial or parallel fashion.
Although specific embodiments have been illustrated and described herein, it should be appreciated that any arrangement calculated to achieve the same purpose may be substituted for the specific embodiments shown. This disclosure is intended to cover any and all adaptations or variations of various embodiments. It is to be understood that the above description has been made in an illustrative fashion, and not a restrictive one. Combinations of the above embodiments, and other embodiments not specifically described herein will be apparent to those of skill in the art upon reviewing the above description. Thus, the scope of various embodiments includes any other applications in which the above compositions, structures, and methods are used.
It is emphasized that the Abstract of the Disclosure is provided to comply with 37 C.F.R. § 1.72(b), requiring an abstract that will allow the reader to quickly ascertain the nature of the technical disclosure. It is submitted with the understanding that it will not be used to interpret or limit the scope or meaning of the claims. In addition, in the foregoing Detailed Description, it can be seen that various features are grouped together in a single embodiment for the purpose of streamlining the disclosure. This method of disclosure is not to be interpreted as reflecting an intention that the claimed embodiments require more features than are expressly recited in each claim. Rather, as the following claims reflect, inventive subject matter lies in less than all features of a single disclosed embodiment. Thus the following claims are hereby incorporated into the Detailed Description, with each claim standing on its own as a separate preferred embodiment. In the appended claims, the terms “including” and “in which” are used as the plain-English equivalents of the respective terms “comprising” and “wherein,” respectively. Moreover, the terms “first,” “second,” and “third,” etc. are used merely as labels, and are not intended to impose numerical requirements on their objects.
Although the subject matter has been described in language specific to structural features and/or methodological acts, it is to be understood that the subject matter defined in the appended claims is not necessarily limited to the specific features or acts described above. Rather, the specific features and acts described above are disclosed as example forms of implementing the claims.
Number | Name | Date | Kind |
---|---|---|---|
9454925 | Grafton | Sep 2016 | B1 |
20040252135 | Ono | Dec 2004 | A1 |
20070109284 | Yamazaki | May 2007 | A1 |
20170221455 | Lee | Aug 2017 | A1 |
Number | Date | Country | |
---|---|---|---|
20180286356 A1 | Oct 2018 | US |