mirror of
https://gitlab.com/zephray/glider.git
synced 2025-01-10 06:03:56 +00:00
Spelling fixes
This commit is contained in:
parent
0c6dd7ac0d
commit
9c0fc0eef4
1 changed files with 181 additions and 163 deletions
344
README.md
344
README.md
|
@ -1,6 +1,6 @@
|
||||||
# Glider
|
# Glider
|
||||||
|
|
||||||
Open source Eink monitor with an emphasis on low latency.
|
Open-source Eink monitor with an emphasis on low latency.
|
||||||
|
|
||||||
Note: This repo only contains the hardware design, the gateware running on the FPGA is my open-source [Caster EPDC](https://gitlab.com/zephray/Caster/) design. This README also contains information about the Caster as well.
|
Note: This repo only contains the hardware design, the gateware running on the FPGA is my open-source [Caster EPDC](https://gitlab.com/zephray/Caster/) design. This README also contains information about the Caster as well.
|
||||||
|
|
||||||
|
@ -8,9 +8,9 @@ Note: This repo only contains the hardware design, the gateware running on the F
|
||||||
|
|
||||||
This is a long document, containing not just information about this project, but also pretty much everything I know about Eink. Given it's a bit hard to gather information about Eink online, I think this is the right thing to do. Use the following table of contents to navigate around.
|
This is a long document, containing not just information about this project, but also pretty much everything I know about Eink. Given it's a bit hard to gather information about Eink online, I think this is the right thing to do. Use the following table of contents to navigate around.
|
||||||
|
|
||||||
Eink is a registered trademark and brand of E Ink Corporation. All the contents provided in this repo are based on publicly available information online and original research. They are not endorsed by Eink in anyway and they may contain errors and/ or inaccurarcies.
|
Eink is a registered trademark and brand of E Ink Corporation. All the contents provided in this repo are based on publicly available information online and original research. They are not endorsed by Eink in any way and they may contain errors and/ or inaccuracies.
|
||||||
|
|
||||||
If you are interested in Eink or any other display technogies, I have a Discord server for that. Feel free to join: https://discord.gg/rtT7euSHQS . (This Discord server is also not endorsed by Eink or any other company. It's not a customer support server.)
|
If you are interested in Eink or any other display technologies, I have a Discord server for that. Feel free to join: https://discord.gg/rtT7euSHQS . (This Discord server is also not endorsed by Eink or any other company. It's not a customer support server.)
|
||||||
|
|
||||||
## Table of Contents
|
## Table of Contents
|
||||||
|
|
||||||
|
@ -55,16 +55,16 @@ If you are interested in Eink or any other display technogies, I have a Discord
|
||||||
### Features
|
### Features
|
||||||
|
|
||||||
- Complete solution for low-latency/ high-refresh-rate EPD monitor
|
- Complete solution for low-latency/ high-refresh-rate EPD monitor
|
||||||
- Supports electrophoretics display panels with parallel I/F (Eink(R), SiPix and DES)
|
- Supports electrophoretic display panels with parallel I/F (Eink(R), SiPix and DES)
|
||||||
- Supports both monochrome and color-filter-array (such as Kaleido(TM)) based color screen
|
- Supports both monochrome and color-filter-array (such as Kaleido(TM)) based color screen
|
||||||
- Extremely low processing delay of \<20 us
|
- Extremely low processing delay of \<20 us
|
||||||
- Supports binary, 4-level grayscale, and 16-level grayscale output modes
|
- Supports binary, 4-level grayscale, and 16-level grayscale output modes
|
||||||
- Latency optimized binary and 4-level grayscale driving modes
|
- Latency-optimized binary and 4-level grayscale driving modes
|
||||||
- Hybrid automatic binary and 16-level grayscale driving mode
|
- Hybrid automatic binary and 16-level grayscale driving mode
|
||||||
- Host software runtime controllable regional update and mode switching
|
- Host software runtime controllable regional update and mode switching
|
||||||
- Hardware bayer dithering, blue-noise dithering, and error-diffusion dithering with no additional latency
|
- Hardware bayer dithering, blue-noise dithering, and error-diffusion dithering with no additional latency
|
||||||
- Controller natively supports FPD-Link (LVDS), DVI (TMDS), and MIPI-DSI input
|
- Controller natively supports FPD-Link (LVDS), DVI (TMDS), and MIPI-DSI input
|
||||||
- Board level design supports USB-C (USB Type-C DisplayPort Alt Mode) and DVI input
|
- Board-level design supports USB-C (USB Type-C DisplayPort Alt Mode) and DVI input
|
||||||
|
|
||||||
### Hardware
|
### Hardware
|
||||||
|
|
||||||
|
@ -72,8 +72,8 @@ If you are interested in Eink or any other display technogies, I have a Discord
|
||||||
|
|
||||||
- Xilinx(R) Spartan-6 LX16 FPGA running Caster
|
- Xilinx(R) Spartan-6 LX16 FPGA running Caster
|
||||||
- DDR3-800 framebuffer memory
|
- DDR3-800 framebuffer memory
|
||||||
- Type-C DisplayPort Alt-Mode video input with on-board PTN3460 DP-LVDS bridge or
|
- Type-C DisplayPort Alt-Mode video input with onboard PTN3460 DP-LVDS bridge or
|
||||||
- DVI (via microHDMI connector) video input with on-board ADV7611 decoder
|
- DVI (via microHDMI connector) video input with onboard ADV7611 decoder
|
||||||
- Epaper power supply with up to 1A peak current on +/-15V rail supporting large panels
|
- Epaper power supply with up to 1A peak current on +/-15V rail supporting large panels
|
||||||
- VCOM kick-back voltage measurement support
|
- VCOM kick-back voltage measurement support
|
||||||
- On-board RaspberryPi(R) RP2040 microcontroller for USB communication and firmware upgrade
|
- On-board RaspberryPi(R) RP2040 microcontroller for USB communication and firmware upgrade
|
||||||
|
@ -89,7 +89,7 @@ This repo hosts the PCB design, firmware source code, and a reference 3D-printab
|
||||||
|
|
||||||
Eink is the brand of a family of paper-like electrophoretic displays. The underlying technology is invented in the MIT Media Lab between 1995 and 1997 by Barrett Comiskey, J.D. Albert, and Joseph Jacobson. They later founded the E Ink Corporation to commercialize this technology.
|
Eink is the brand of a family of paper-like electrophoretic displays. The underlying technology is invented in the MIT Media Lab between 1995 and 1997 by Barrett Comiskey, J.D. Albert, and Joseph Jacobson. They later founded the E Ink Corporation to commercialize this technology.
|
||||||
|
|
||||||
Nowadays they are commonly used on e-readers and electronic shelf labels. You’ve probably seen them on Kindle, or in stores, or maybe in some train stations as well.
|
Nowadays they are commonly used on e-readers and electronic shelf labels. You’ve probably seen them on Kindle, in stores, or maybe in some train stations as well.
|
||||||
|
|
||||||
| eReader/ Tablets | Electronic Shelf Label | Digital Signage |
|
| eReader/ Tablets | Electronic Shelf Label | Digital Signage |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
|
@ -97,7 +97,7 @@ Nowadays they are commonly used on e-readers and electronic shelf labels. You’
|
||||||
|
|
||||||
(Source: https://www.eink.com/application, image copyright Eink corporation)
|
(Source: https://www.eink.com/application, image copyright Eink corporation)
|
||||||
|
|
||||||
This section gives an overview of the electrophoretics displays, including the screen panels available and underlying technology. Note this project obviously doesn't and can't support all electrophoretic screens. This documentation also solely focuses on using existing off-the-shelf screen panels rather than the physics or manufacturing process of one.
|
This section gives an overview of the electrophoretic displays, including the screen panels available and underlying technology. Note this project doesn't and can't support all electrophoretic screens. This documentation also solely focuses on using existing off-the-shelf screen panels rather than the physics or manufacturing process of one.
|
||||||
|
|
||||||
### Basic Theory of Operation
|
### Basic Theory of Operation
|
||||||
|
|
||||||
|
@ -107,15 +107,15 @@ In the simplest form, you have charged particles with different colors, disperse
|
||||||
|
|
||||||
(Source: https://www.eink.com/tech/detail/How_it_works , copyright Eink Corporation)
|
(Source: https://www.eink.com/tech/detail/How_it_works , copyright Eink Corporation)
|
||||||
|
|
||||||
There are multiple technologies based on this basic concept, namely Eink’s micro-capsule display, SiPix (now acquired by Eink)’s micro-cup display, and WFT’s DES display. They differs in specifics ways of confining the particles in containers, but otherwise very similar.
|
There are multiple technologies based on this basic concept, namely Eink’s micro-capsule display, SiPix (now acquired by Eink)’s micro-cup display, and WFT’s DES display. They differ in specific ways of confining the particles in containers, but otherwise very similar.
|
||||||
|
|
||||||
The pixels on the screen are typically arranged as a 2D array, driven with TFTs. The pixels are scanned/ driven periodically at a fixed refresh rate, typically ranging from 50Hz to 120Hz. Applying positive voltage on the pixel will typically drive the particles towards the white state, while applying negative voltage will drive the particles towards the black state. This is similar to active matrix TN/IPS LCDs, which also uses 2D TFT arrays and uses electrical fields for changing state. However unlike LCDs, EPDs maintain their state after the electrical field is removed. So unlike LCDs which require continuously refreshing, the EPDs only need to be refreshed till the pixels are fully driven.
|
The pixels on the screen are typically arranged as a 2D array, driven with TFTs. The pixels are scanned/ driven periodically at a fixed refresh rate, typically ranging from 50Hz to 120Hz. Applying positive voltage on the pixel will typically drive the particles toward the white state while applying negative voltage will drive the particles towards the black state. This is similar to active matrix TN/IPS LCDs, which also use 2D TFT arrays and electrical fields for changing state. However, unlike LCDs, EPDs maintain their state after the electrical field is removed. So unlike LCDs which require continuous refreshing, the EPDs only need to be refreshed till the pixels are fully driven.
|
||||||
|
|
||||||
In terms of driving the screen panel, depending on the pixel value (1 or 0), each pixel would be driven either with a positive voltage or a negative voltage. A global counter can be used to count the frames elapsed, and stop driving the pixels after a predefined period of time (for example, 100ms). Two framebuffers are typically used for determining if the pixel has changed color or not. If not, then the pixel does not need to be driven.
|
In terms of driving the screen panel, depending on the pixel value (1 or 0), each pixel would be driven either with a positive voltage or a negative voltage. A global counter can be used to count the frames elapsed and stop driving the pixels after a predefined period of time (for example, 100ms). Two framebuffers are typically used for determining if the pixel has changed color or not. If not, then the pixel does not need to be driven.
|
||||||
|
|
||||||
### Advantages and Disadvantages
|
### Advantages and Disadvantages
|
||||||
|
|
||||||
In terms of display quality, EPDs are no match for modern IPS LCDs. The following is a comparison table of key parameterics. Specific number would vary depending on the screen used, but should be within the same ballpack.
|
In terms of display quality, EPDs are no match for modern IPS LCDs. The following is a comparison table of key parameters. The specific number would vary depending on the screen used but should be within the same ballpark.
|
||||||
|
|
||||||
| | Monochrome EPD | CFA-based Color EPD | Transmissive TFT IPS LCD | Reflective TFT TN LCD |
|
| | Monochrome EPD | CFA-based Color EPD | Transmissive TFT IPS LCD | Reflective TFT TN LCD |
|
||||||
|-|-|-|-|-|
|
|-|-|-|-|-|
|
||||||
|
@ -125,7 +125,7 @@ In terms of display quality, EPDs are no match for modern IPS LCDs. The followin
|
||||||
| Reflectivity | ~45% | ~25% | N/A | ~15% |
|
| Reflectivity | ~45% | ~25% | N/A | ~15% |
|
||||||
| Response Time | ~150ms | ~150ms | ~10ms | ~15ms |
|
| Response Time | ~150ms | ~150ms | ~10ms | ~15ms |
|
||||||
|
|
||||||
It has a few advantages. It reflect lights instead of emitting lights, so it generally consumes less power and can be used outdoors, etc. It’s also bistable, means that it retains the image after the power has been removed. Personally, the biggest differentiating factor for me (author of this README) is that it looks like paper.
|
It has a few advantages. It reflects lights instead of emitting lights, so it generally consumes less power and can be used outdoors, etc. It’s also bistable, which means that it retains the image after the power has been removed. Personally, the biggest differentiating factor for me (author of this README) is that it looks like paper.
|
||||||
|
|
||||||
![rlcd-vs-eink](assets/rlcd_eink.gif)
|
![rlcd-vs-eink](assets/rlcd_eink.gif)
|
||||||
|
|
||||||
|
@ -138,11 +138,11 @@ The image above shows a comparison between reflective TFT LCD (SHARP memory LCD
|
||||||
|
|
||||||
There are many other reflective or bistable display technologies. They are all interesting displays on their own, but none of them feels like paper (yet).
|
There are many other reflective or bistable display technologies. They are all interesting displays on their own, but none of them feels like paper (yet).
|
||||||
|
|
||||||
Overally, there is no single perfect display technology. Each has its own unique strength. Pick the right one for your project.
|
Overall, there is no single perfect display technology. Each has its own unique strength. Pick the right one for your project.
|
||||||
|
|
||||||
### The Role of Eink Controller
|
### The Role of Eink Controller
|
||||||
|
|
||||||
The Eink controller is in some ways similar to the display controller (DC/ CRTC) + timing controller (TCON) in a typical LCD based system. It takes the raw image data and convert it to signals required to drive the screen.
|
The Eink controller is in some ways similar to the display controller (DC/ CRTC) + timing controller (TCON) in a typical LCD-based system. It takes the raw image data and converts it to signals required to drive the screen.
|
||||||
|
|
||||||
![eink-controller](assets/eink_controller.svg)
|
![eink-controller](assets/eink_controller.svg)
|
||||||
|
|
||||||
|
@ -155,53 +155,53 @@ To understand the actual work of an eink controller, start from the basic concep
|
||||||
| White | Black | Apply negative voltage |
|
| White | Black | Apply negative voltage |
|
||||||
| White | White | No operation |
|
| White | White | No operation |
|
||||||
|
|
||||||
The controller need to store and maintain the screen state inside of its own buffer memory, so it would typically have a large on-chip SRAM or an off-chip SDRAM controller. The controller should also have a timer to ensure the screen doesn't get overdriven or underdriven.
|
The controller needs to store and maintain the screen state inside of its own buffer memory, so it would typically have a large on-chip SRAM or an off-chip SDRAM controller. The controller should also have a timer to ensure the screen doesn't get overdriven or underdriven.
|
||||||
|
|
||||||
Controller often use the so-called "[waveform](#understanding-waveform)" to replace the action colume of the previous table. Instead of hardcoding the action for state transition, the actions are stored into a look-up-table (LUT) which can be modified at runtime to allow higher flexibility.
|
The controller often uses the so-called "[waveform](#understanding-waveform)" to replace the action column of the previous table. Instead of hardcoding the action for state transition, the actions are stored into a look-up-table (LUT) which can be modified at runtime to allow higher flexibility.
|
||||||
|
|
||||||
Controllers may also offer more advanced features such as [dithering](#dithering) acceleration, multiple region update, automatic LUT selection, etc.
|
Controllers may also offer more advanced features such as [dithering](#dithering) acceleration, multiple region updates, automatic LUT selection, etc.
|
||||||
|
|
||||||
### Screen Panel Types
|
### Screen Panel Types
|
||||||
|
|
||||||
As discussed in the previous section, an Eink screen need to be coupled to an Eink controller to function. Aside from that, screen also needs high voltage drivers to drive the TFTs and the pixels. Virtually all E-paper panels use either COG (Chip-on-Glass) or TAB (Tape Auto Bonding) to integrate some chips onto the screen panel itself. Most of the screens available today can be divided into two categories based on whether or not the controller is integrated in:
|
As discussed in the previous section, an Eink screen needs to be coupled to an Eink controller to function. Aside from that, the screen also needs high-voltage drivers to drive the TFTs and the pixels. Virtually all E-paper panels use either COG (Chip-on-Glass) or TAB (Tape Auto Bonding) to integrate some chips onto the screen panel itself. Most of the screens available today can be divided into two categories based on whether or not the controller is integrated in:
|
||||||
|
|
||||||
![screen-types](assets/screen_types.svg)
|
![screen-types](assets/screen_types.svg)
|
||||||
|
|
||||||
Here is a non-exhaustive list of the type based on their size: (the size or resolution is not related to or limited by the type, it is just for a certain size, the vendors tend to make them the same type.)
|
Here is a non-exhaustive list of the types based on their size: (the size or resolution is not related to or limited by the type, it is just for a certain size, and the vendors tend to make them the same type.)
|
||||||
|
|
||||||
- Screens without controller: 4.3", 6.0", 7.8", 8.0", 9.7", 10.3", 13.3", 25.3", 31.2", 42"
|
- Screens without controller: 4.3", 6.0", 7.8", 8.0", 9.7", 10.3", 13.3", 25.3", 31.2", 42"
|
||||||
- Screens with controller: 1.02", 1.54", 2.13", 2.6", 2.9", 3.71", 4.2", 5.65", 5.83", 7.5", 12.48"
|
- Screens with controller: 1.02", 1.54", 2.13", 2.6", 2.9", 3.71", 4.2", 5.65", 5.83", 7.5", 12.48"
|
||||||
|
|
||||||
One may notice that almost all e-readers/ e-ink cellphones use screens without controller, while almost all e-ink electronic shelf labels (ESL) use screens with controller. This gives some hints about the advantages and disadvantages of two types:
|
One may notice that almost all e-readers/ e-ink cellphones use screens without controllers, while almost all e-ink electronic shelf labels (ESL) use screens with controllers. This gives some hints about the advantages and disadvantages of two types:
|
||||||
|
|
||||||
| | Without Controller | With Controller |
|
| | Without Controller | With Controller |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| System Cost | High. A dedicated controller or SoC with integrated controller is usually required. Needs a dedicated power supply. | Low. Virtually any MCUs could drive the screen directly, and the power supply is integrated in. |
|
| System Cost | High. A dedicated controller or SoC with an integrated controller is usually required. Needs a dedicated power supply. | Low. Virtually any MCU could drive the screen directly, and the power supply is integrated in. |
|
||||||
| Greyscale Levels | Generally 16 (4bpp), up to 32 (5bpp) | Generally 2 (BW only) or 4 (2bpp), with some hack, up to 16 (4bpp) |
|
| Greyscale Levels | Generally 16 (4bpp), up to 32 (5bpp) | Generally 2 (BW only) or 4 (2bpp), with some hack, up to 16 (4bpp) |
|
||||||
| Refresh Speed | Generally fast (100ms~300ms) for BW. Depends on the screen used and the system architecture | Generally fast (100ms~300ms) for BW if the partial refresh is enabled. Greyscales much slower, BWR or BWY screens would be even slower.
|
| Refresh Speed | Generally fast (100ms~300ms) for BW. Depends on the screen used and the system architecture | Generally fast (100ms~300ms) for BW if the partial refresh is enabled. Greyscales are much slower, BWR or BWY screens would be even slower.
|
||||||
| Total Update Latency | Generally the same as refresh time. Depends on the system architecture | Slow. Ranging from 100ms to several seconds based on the resolution. |
|
| Total Update Latency | Generally the same as refresh time. Depends on the system architecture | Slow. Ranging from 100ms to several seconds based on the resolution. |
|
||||||
|
|
||||||
Please keep in mind the discussion is about off-the-shelf screens you can buy today. These tradeoffs do not necessarily come from the fact the controller is integrated or not.
|
Please keep in mind the discussion is about off-the-shelf screens you can buy today. These tradeoffs do not necessarily come from the fact the controller is integrated or not.
|
||||||
|
|
||||||
Note that I mentioned the refresh speed and total update latency. They are different:
|
Note that I mentioned the refresh speed and total update latency. They are different:
|
||||||
|
|
||||||
The refresh speed refers to the time it takes to start refreshing the screen: from starting seeing screen changing, to the screen finish showing the new content.
|
The refresh speed refers to the time it takes to start refreshing the screen: from starting to seeing screen changing, to the screen finish showing the new content.
|
||||||
|
|
||||||
The total update latency refers to the latency when the processor needs to update the screen, to the screen finish showing the new content. As you could see, this is the biggest issue for screens with controllers. This is the main reason why they are almost never used on e-readers or cellphones or PC monitors.
|
The total update latency refers to the latency when the processor needs to update the screen, to the screen finish showing the new content. As you can see, this is the biggest issue for screens with controllers. This is the main reason why they are rarely used on e-readers cell phones or PC monitors.
|
||||||
|
|
||||||
![screen-controller-diagram](assets/screen_cntlr.svg)
|
![screen-controller-diagram](assets/screen_cntlr.svg)
|
||||||
|
|
||||||
This diagram illustrates the difference between two. It should be noted that the screens without controller have the flexibility to be driven quickly, but the system designer might not architect the system for low latency.
|
This diagram illustrates the difference between the two. It should be noted that the screens without controllers have the flexibility to be driven quickly, but the system designer might not architect the system for low latency.
|
||||||
|
|
||||||
### Using Screen with Integrated Controller
|
### Using Screen with Integrated Controller
|
||||||
|
|
||||||
Screens with integrated controller have almost everything already integrated. Common display panels in this type only need few external capacitors, inductors, and MOSFETs to support the integrated bipolar power supply circuit, then it could be hooked up to MCUs or MPUs using common interfaces like SPI or I2C. There are a lot of driving boards and examples of these screens available online.
|
Screens with integrated controllers have almost everything already integrated. Common display panels of this type only need a few external capacitors, inductors, and MOSFETs to support the integrated bipolar power supply circuit, then it could be hooked up to MCUs or MPUs using common interfaces like SPI or I2C. There are a lot of driving boards and examples of these screens available online.
|
||||||
|
|
||||||
To be expanded (TODO)
|
To be expanded (TODO)
|
||||||
|
|
||||||
### Using Screen without Integrated Controller
|
### Using Screen without Integrated Controller
|
||||||
|
|
||||||
This could get complicated. Note I used a lot of "generally" in the previous comparison table because there are many things one could do to drive them. Some of them would certainly impact the performance. The main issue here the controller chip. There are three solutions to drive these screen:
|
This could get complicated. Note I used a lot of "generally" in the previous comparison table because there are many things one could do to drive them. Some of them would certainly impact the performance. The main issue here is the controller chip. There are three solutions to drive these screens:
|
||||||
|
|
||||||
- Using a dedicated controller chip to drive the screen
|
- Using a dedicated controller chip to drive the screen
|
||||||
- Using an SoC that has an integrated controller
|
- Using an SoC that has an integrated controller
|
||||||
|
@ -214,10 +214,10 @@ Then, again here is a comparison between them:
|
||||||
| Resolution | UXGA+ | UXGA+ | Limited by MCU RAM. Up to XGA with SRAM, UXGA with PSRAM, UXGA+ with DDR |
|
| Resolution | UXGA+ | UXGA+ | Limited by MCU RAM. Up to XGA with SRAM, UXGA with PSRAM, UXGA+ with DDR |
|
||||||
| Greyscale | Up to 32 | Up to 32 | Up to 32 |
|
| Greyscale | Up to 32 | Up to 32 | Up to 32 |
|
||||||
| Partial Update | Yes | Yes | Yes |
|
| Partial Update | Yes | Yes | Yes |
|
||||||
| Total Update Latency | Depends. Could be very close as refresh speed, could be slow like screens with controller | Same as refresh speed | Same as refresh speed if data is internally generated (not streaming from an external device such as a PC) |
|
| Total Update Latency | Depends. Could be very close to refresh speed, could be slow like screens with controller | Same as refresh speed | Same as refresh speed if data is internally generated (not streaming from an external device such as a PC) |
|
||||||
| Suitable Applications | IoT devices, E-readers, cellphones, E-ink monitors. possibly E-ink laptops | Advanced IoT devices, E-readers, cellphones, E-ink typewriters, possibly lower performance E-ink laptops | When using MCU: IoT devices, large ESLs, simple DIY E-readers. When using MPU: Same as SoC with integrated controller |
|
| Suitable Applications | IoT devices, E-readers, cellphones, E-ink monitors. possibly E-ink laptops | Advanced IoT devices, E-readers, cellphones, E-ink typewriters, possibly lower performance E-ink laptops | When using MCU: IoT devices, large ESLs, simple DIY E-readers. When using MPU: Same as SoC with integrated controller |
|
||||||
|
|
||||||
When using a dedicated controller, it could accept data from external devices. This allows it to be used in various different types of applications. Ranging from IoT devices, ESLs, to PC monitors with relatively fast refresh rate and low latency.
|
When using a dedicated controller, it could accept data from external devices. This allows it to be used in various different types of applications. Ranging from IoT devices, and ESLs, to PC monitors with relatively fast refresh rate and low latency.
|
||||||
|
|
||||||
When using SoC or MCU, the display content is generated by the SoC or MCU itself, which ultimately is limited by the capability of the SoC or MCU. Given the current SoCs with E-ink display controllers are usually limited in performance, the application is limited. The same goes for MCU, it does what an MCU could do. You could find ways to stream video data into SoC or MCUs by using USB, camera interface, WiFi, etc., but this might not be optimal.
|
When using SoC or MCU, the display content is generated by the SoC or MCU itself, which ultimately is limited by the capability of the SoC or MCU. Given the current SoCs with E-ink display controllers are usually limited in performance, the application is limited. The same goes for MCU, it does what an MCU could do. You could find ways to stream video data into SoC or MCUs by using USB, camera interface, WiFi, etc., but this might not be optimal.
|
||||||
|
|
||||||
|
@ -226,13 +226,13 @@ When using SoC or MCU, the display content is generated by the SoC or MCU itself
|
||||||
- Specialized controller chip
|
- Specialized controller chip
|
||||||
- Closed-source
|
- Closed-source
|
||||||
- EPSON S1D13xxx: Widely used EPD controller in early E-readers. Proprietary, no documents available. Probably EOL.
|
- EPSON S1D13xxx: Widely used EPD controller in early E-readers. Proprietary, no documents available. Probably EOL.
|
||||||
- IT8951: Used on waveshare EPD Hat. Documents available, works with large EPDs up to 2048x2048. The drawback is the speed as the interface between processor and IT8951 could be slow. This is similar to the situation on screens with integrated controller
|
- IT8951: Used on the waveshare EPD Hat. Documents are available. It works with large EPDs up to 2048x2048. The drawback is the speed as the interface between processor and IT8951 could be slow. This is similar to the situation on screens with integrated controller
|
||||||
- T1000: Also known as IT8957, upgraded model of IT8951. It supports even higher resolution. It features higher speed MIPI DSI interface to mitigate the slow speed of IT8951.
|
- T1000: Also known as IT8957, upgraded model of IT8951. It supports even higher resolution. It features a higher speed MIPI DSI interface to mitigate the slow speed of IT8951.
|
||||||
- Waveshare HDMI driver board: FPGA-based controller. Closed source but easily purchasable, could be integrated into larger projects as a module.
|
- Waveshare HDMI driver board: FPGA-based controller. Closed source but easily purchasable, could be integrated into larger projects as a module.
|
||||||
- Open-source
|
- Open-source
|
||||||
- This project (Caster + Glider): FPGA-based controller, multiple update modes, ultra low latency processing, wide range of screen support.
|
- This project (Caster + Glider): FPGA-based controller, multiple update modes, ultra-low latency processing, and wide range of screen support.
|
||||||
- https://hackaday.io/project/21607-paperback-a-desktop-epaper-monitor: FPGA-based controller. However, doesn't support partial update mode and slower speed.
|
- https://hackaday.io/project/21607-paperback-a-desktop-epaper-monitor: FPGA-based controller. However, doesn't support partial update mode and slower speed.
|
||||||
- https://hackaday.io/project/21168-fpga-eink-controller: FPGA-based controller, supports vendor waveform with reasonable speed.
|
- https://hackaday.io/project/21168-fpga-eink-controller: FPGA-based controller supports vendor waveform with reasonable speed.
|
||||||
- SoC with integrated controller
|
- SoC with integrated controller
|
||||||
- RK29xx: Fairly old, Cortex-A8 based (RPi 1 level performance), 55nm, EOL
|
- RK29xx: Fairly old, Cortex-A8 based (RPi 1 level performance), 55nm, EOL
|
||||||
- RK3026/RK3028: Fairly old, Cortex-A9 based (RPi 2 level performance), 40nm, EOL
|
- RK3026/RK3028: Fairly old, Cortex-A9 based (RPi 2 level performance), 40nm, EOL
|
||||||
|
@ -246,14 +246,14 @@ When using SoC or MCU, the display content is generated by the SoC or MCU itself
|
||||||
- RK3566/RK3568: Cortex-A55 based (RPi 3 level performance), 22nm, in production
|
- RK3566/RK3568: Cortex-A55 based (RPi 3 level performance), 22nm, in production
|
||||||
- RK3576: Cortex-A72 + A53 based (RPi 4-5 level performance), 8nm, in production
|
- RK3576: Cortex-A72 + A53 based (RPi 4-5 level performance), 8nm, in production
|
||||||
- MCU/SoC + Software TCON
|
- MCU/SoC + Software TCON
|
||||||
- http://essentialscrap.com/eink/waveforms.html: One of the earliest e-ink hack. Limited in performance but still could be used as a reference
|
- http://essentialscrap.com/eink/waveforms.html: One of the earliest e-ink hacks. Limited in performance but still could be used as a reference
|
||||||
- NekoCal: One of the earliest e-ink software TCON with greyscale support. Used to be available as a DIY kit. No longer updated, still could be used as a reference
|
- NekoCal: One of the earliest e-ink software TCON with greyscale support. Used to be available as a DIY kit. No longer updated, still could be used as a reference
|
||||||
- InkPlate 6/10: Commercially available. Based on ESP32.
|
- InkPlate 6/10: Commercially available. Based on ESP32.
|
||||||
- EPDiy: Based on ESP32, supports a lot of different screens, recommended if want to build some device with ESP32+Eink or embedding it into a larger project.
|
- EPDiy: Based on ESP32, supports a lot of different screens, recommended if want to build some device with ESP32+Eink or embed it into a larger project.
|
||||||
|
|
||||||
#### Interface Signals and Timing
|
#### Interface Signals and Timing
|
||||||
|
|
||||||
The interface signals and timing are fairly similar to LCDs without controller. Following is the list of signals typically found on EPDs:
|
The interface signals and timing are fairly similar to LCDs without a controller. Following is the list of signals typically found on EPDs:
|
||||||
|
|
||||||
- GDOE/ MODE: Gate driver output enable
|
- GDOE/ MODE: Gate driver output enable
|
||||||
- GDCLK/ CKV: Gate driver clock (like HSYNC in LCD)
|
- GDCLK/ CKV: Gate driver clock (like HSYNC in LCD)
|
||||||
|
@ -264,9 +264,9 @@ The interface signals and timing are fairly similar to LCDs without controller.
|
||||||
- SDCE/ XSTL: Source driver start pulse (like DE in LCD)
|
- SDCE/ XSTL: Source driver start pulse (like DE in LCD)
|
||||||
- SD: Source driver data (8-bit or 16-bit)
|
- SD: Source driver data (8-bit or 16-bit)
|
||||||
|
|
||||||
SD signals goes into the source driver, typically the X direction. GD signals goes into the gate driver, typically the Y direction. It's a 2D array, gate driver selects one line at a time, and the source driver output the voltage for all the pixels in that line.
|
SD signals go into the source driver, typically in the X direction. GD signals go into the gate driver, typically in the Y direction. It's a 2D array, the gate driver selects one line at a time, and the source driver outputs the voltage for all the pixels in that line.
|
||||||
|
|
||||||
Conceptually, it's like raster scan on a CRT. To send one field of data, both GD and SD are reset to the start position by using the start pulse signal. Data are then transmitted into the source driver 4 or 8 pixel at a time. Once the line has been fully transmitted, the source driver is reset to the beginning position by start pulse signal, and the gate driver moves to the next line by a pulse on the gate driver clock. Once all lines have been scanned, the entire process repeats for the next field.
|
Conceptually, it's like a raster scan on a CRT. To send one field of data, both GD and SD are reset to the start position by using the start pulse signal. Data are then transmitted into the source driver 4 or 8 pixels at a time. Once the line has been fully transmitted, the source driver is reset to the beginning position by a start pulse signal, and the gate driver moves to the next line by a pulse on the gate driver clock. Once all lines have been scanned, the entire process repeats for the next field.
|
||||||
|
|
||||||
One notable difference with LCD is that each pixel is represented by 2 bits. This, however, doesn't mean each pixel is 2bpp or 4-level greyscale. The 2-bit per pixel is used to encode the voltage applied to the pixel:
|
One notable difference with LCD is that each pixel is represented by 2 bits. This, however, doesn't mean each pixel is 2bpp or 4-level greyscale. The 2-bit per pixel is used to encode the voltage applied to the pixel:
|
||||||
|
|
||||||
|
@ -275,7 +275,7 @@ One notable difference with LCD is that each pixel is represented by 2 bits. Thi
|
||||||
- 10: Positive voltage
|
- 10: Positive voltage
|
||||||
- 11: No voltage
|
- 11: No voltage
|
||||||
|
|
||||||
Just like CRT/ LCD, there are also blanking periods in the entire timing (means it's just waiting without active pixel data being sent). They have identical meaning to CRT/ LCD systems:
|
Just like CRT/ LCD, there are also blanking periods in the entire timing (which means it's just waiting without active pixel data being sent). They have identical meanings to CRT/ LCD systems:
|
||||||
|
|
||||||
![display-timings](assets/display-timings.png)
|
![display-timings](assets/display-timings.png)
|
||||||
|
|
||||||
|
@ -335,13 +335,13 @@ More explanation can be found at [http://essentialscrap.com/eink/index.html](htt
|
||||||
|
|
||||||
### Understanding Waveform
|
### Understanding Waveform
|
||||||
|
|
||||||
The waveform is a look up table for the eink controller to determine how to drive the pixels, mostly useful for greyscale image display, but generally used for binary image display as well.
|
The waveform is a look-up table for the eink controller to determine how to drive the pixels, mostly useful for greyscale image display, but generally used for binary image display as well.
|
||||||
|
|
||||||
The look up table has 3 inputs (dimensions): frame number, source grayscale level, destination grayscale level. During the update process, for a certain pixel, the source and destination level stays the same, and the frame number increases each frame. The look up process is done for every pixel every frame. The controller may choose different LUTs depending on the ambient temperature. Mode switching is also implemented by simply switching between different LUTs.
|
The look-up-table has 3 inputs (dimensions): frame number, source grayscale level, and destination grayscale level. During the update process, for a certain pixel, the source and destination level stays the same, and the frame number increases each frame. The look-up process is done for every pixel every frame. The controller may choose different LUTs depending on the ambient temperature. Mode switching is also implemented by simply switching between different LUTs.
|
||||||
|
|
||||||
This is essentially what typically eink controller does. For each pixel, look up in the table to determine the voltage to use. Repeat this for a couple of frames with an incrementing frame counter, until all pixels are fully driven.
|
This is essentially what typically eink controller does. For each pixel, look up in the table to determine the voltage to use. Repeat this for a couple of frames with an incrementing frame counter, until all pixels are fully driven.
|
||||||
|
|
||||||
It should be obvious that the waveform file itself is independent to the resolution as the waveform only cares about single pixel. With an incorrect or un-optimal waveform, the screen should at least display some recognizable image.
|
It should be obvious that the waveform file itself is independent of the resolution as the waveform only cares about a single pixel. With an incorrect or un-optimal waveform, the screen should at least display some recognizable image.
|
||||||
|
|
||||||
#### Waveform Example
|
#### Waveform Example
|
||||||
|
|
||||||
|
@ -351,13 +351,13 @@ Take one line from that file:
|
||||||
|
|
||||||
```6,13,0,0,0,0,0,0,0,0,0,2,1,1,1,1,1,1,1,1,1,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,0```
|
```6,13,0,0,0,0,0,0,0,0,0,2,1,1,1,1,1,1,1,1,1,1,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,1,0```
|
||||||
|
|
||||||
This means from greyscale level 6 to level 13, it needs to go through the following sequence. Each number means the operation on that frame, 0 is no-operation, 1 is darken, and 2 is lighten. In this case, there are 38 frames, first 9 frames do nothing, then lighten for 1 frame, darken for 10 frames, lighten for 16 frames, and finally darken for 1 frame and no-operation for the last frame. This is the sequence to change a pixel from level 6 to level 13. Such lookup is done for every pixel on every frame.
|
This means from greyscale level 6 to level 13, it needs to go through the following sequence. Each number means the operation on that frame, 0 is no-operation, 1 is darken, and 2 is lighten. In this case, there are 38 frames, first 9 frames do nothing, then lighten for 1 frame, darken for 10 frames, lighten for 16 frames, and finally darken for 1 frame and have no operation for the last frame. This is the sequence to change a pixel from level 6 to level 13. Such lookup is done for every pixel on every frame.
|
||||||
|
|
||||||
For specifics on waveform file formats, check the [Working with Waveforms](#working-with-waveforms) section.
|
For specifics on waveform file formats, check the [Working with Waveforms](#working-with-waveforms) section.
|
||||||
|
|
||||||
#### Waveform Modes
|
#### Waveform Modes
|
||||||
|
|
||||||
To give system designers more flexibility, Eink controllers often offers multiple "modes", like binary mode, 16-level grayscale mode, 16-level grayscale mode with reduced flashing, 4-level grayscale mode, etc.
|
To give system designers more flexibility, Eink controllers often offer multiple "modes", like binary mode, 16-level grayscale mode, 16-level grayscale mode with reduced flashing, 4-level grayscale mode, etc.
|
||||||
|
|
||||||
The waveform provided by Eink has many modes. There is a good document from Eink describing the modes:
|
The waveform provided by Eink has many modes. There is a good document from Eink describing the modes:
|
||||||
|
|
||||||
|
@ -365,14 +365,14 @@ https://www.waveshare.net/w/upload/c/c4/E-paper-mode-declaration.pdf
|
||||||
|
|
||||||
It provides a good overview of the modes. I am just going to add some comments.
|
It provides a good overview of the modes. I am just going to add some comments.
|
||||||
|
|
||||||
- GC in the GC16 stands for "greyscale clearing". GC does not stands for greyscale. There are 16-level greyscale modes that aren't called GC16.
|
- GC in the GC16 stands for "greyscale clearing". GC does not stand for greyscale. There are 16-level greyscale modes that aren't called GC16.
|
||||||
- Officially there is no 32-level greyscale modes (yet). There are 5bit waveforms, which means they internally use 5 bits for each pixel, which potentially allows up to 32-level greyscale, but no such waveform exists (yet).
|
- Officially there are no 32-level greyscale modes (yet). There are 5-bit waveforms, which means they internally use 5 bits for each pixel, which potentially allows up to 32-level greyscale, but no such waveform exists (yet).
|
||||||
- These is no 16 level greyscale modes without flashing. The DU4 is the only greyscale mode that's non-flashing.
|
- There are no 16-level greyscale modes without flashing. The DU4 is the only greyscale mode that's non-flashing.
|
||||||
- The GL16 mode, as described, only works for black text on white background. When refreshing greyscale images, the GL16 is similar to the GC16.
|
- The GL16 mode, as described, only works for black text on a white background. When refreshing greyscale images, the GL16 is similar to the GC16.
|
||||||
- The GLR16 mode is also called the REGAL mode, and the GLD16 mode is also called as the REGAL-D mode.
|
- The GLR16 mode is also called the REGAL mode, and the GLD16 mode is also called the REGAL-D mode.
|
||||||
- Eink doesn't even know if it should be spelled as REAGL or REGAL: Google search "REAGL site:eink.com" and "REGAL site:eink.com" both returned several results.
|
- Eink doesn't even know if it should be spelled as REAGL or REGAL: Google search "REAGL site:eink.com" and "REGAL site:eink.com" both returned several results.
|
||||||
- Eink provided waveform usually implements all these modes, however it is not always required. The waveform file may also contain waveform tables in other orders.
|
- Eink-provided waveform usually implements all these modes, however it is not always required. The waveform file may also contain waveform tables in other orders.
|
||||||
- In terms of the waveform, the waveform for GL16, GLR16, and GLD16 are identical. This is expected, the REGAL requires additional algorithm on the host image processing, and is not a technology based on tweaking the waveform.
|
- In terms of the waveform, the waveform for GL16, GLR16, and GLD16 are identical. This is expected, the REGAL requires an additional algorithm on the host image processing and is not a technology based on tweaking the waveform.
|
||||||
|
|
||||||
#### Waveform Tweaks
|
#### Waveform Tweaks
|
||||||
|
|
||||||
|
@ -384,7 +384,7 @@ Other than full white and full black, with appropriate modulation, Eink screens
|
||||||
|
|
||||||
![greyscale](assets/eink_32g.jpg)
|
![greyscale](assets/eink_32g.jpg)
|
||||||
|
|
||||||
For grayscale display, the basic idea is simple. If the pixel is not fully driven (say only drives for 50ms while it takes 100ms to reach full black/ white), it would stay in a gray state.
|
For grayscale displays, the basic idea is simple. If the pixel is not fully driven (say only drives for 50ms while it takes 100ms to reach full black/ white), it would stay in a gray state.
|
||||||
|
|
||||||
There are two ways of achieving this modulation:
|
There are two ways of achieving this modulation:
|
||||||
- Modulate the frame time
|
- Modulate the frame time
|
||||||
|
@ -394,9 +394,9 @@ Both are possible, as described below
|
||||||
|
|
||||||
#### Frame Time Modulation
|
#### Frame Time Modulation
|
||||||
|
|
||||||
This method changes the drive time by changing the length of a single frame. The screen would only be driven for 15 or 31 frames for 16-level and 32-level greyscale, but the frame time (thus frame rate) is altered to provide the desired driving time. The LUT would be a one dimension look up table, only containing the incremental time required to drive to the next greyscale level. The source/ gate driver output enable line maybe toggled to achieve the desired driving time.
|
This method changes the drive time by changing the length of a single frame. The screen would only be driven for 15 or 31 frames for 16-level and 32-level greyscale, but the frame time (thus frame rate) is altered to provide the desired driving time. The LUT would be a one-dimension look-up table, only containing the incremental time required to drive to the next greyscale level. The source/ gate driver output enables the line to be toggled to achieve the desired driving time.
|
||||||
|
|
||||||
This method doesn't seem to be implemented in any commercial solutions and is significantly slower than the second method. But it certainly works. In fact the 32-level greyscale demo shown in the picture above is achieved using this method.
|
This method doesn't seem to be implemented in any commercial solutions and is significantly slower than the second method. But it certainly works. The 32-level greyscale demo shown in the picture above is achieved using this method.
|
||||||
|
|
||||||
#### Frame Count Modulation
|
#### Frame Count Modulation
|
||||||
|
|
||||||
|
@ -409,15 +409,15 @@ This method changes the drive time by changing the number of frames being applie
|
||||||
| Black | Light Grey | VPOS | VNEG | VPOS | VPOS | NOP |
|
| Black | Light Grey | VPOS | VNEG | VPOS | VPOS | NOP |
|
||||||
| Black | White | VPOS | VNEG | VPOS | VPOS | VPOS |
|
| Black | White | VPOS | VNEG | VPOS | VPOS | VPOS |
|
||||||
|
|
||||||
Note how it alternates between VPOS and VNEG in the beginning. This is often called the "activation phase" to improve contrast ratio. Putting this detail aside, it changes the number of VPOS frames to settle down on different grey levels.
|
Note how it alternates between VPOS and VNEG in the beginning. This is often called the "activation phase" to improve the contrast ratio. Putting this detail aside, it changes the number of VPOS frames to settle down on different grey levels.
|
||||||
|
|
||||||
Actual grayscale driving sequence used in the commercial implementation is more complex than that, often involving switching the pixel towards black/white a few times before settling. This design is partially due to the limited time control granularity and other temperature/ manufacturing variance related concerns. Some side-effects of such a driving sequence are that the refreshing process is “flashing”, and is slower compared to displaying only 1-bit binary image.
|
The actual grayscale driving sequence used in the commercial implementation is more complex than that, often involving switching the pixel towards black/white a few times before settling. This design is partially due to the limited time control granularity and other temperature/ manufacturing variance-related concerns. Some side-effects of such a driving sequence are that the refreshing process is “flashing”, and is slower compared to displaying only a 1-bit binary image.
|
||||||
|
|
||||||
### Color Display
|
### Color Display
|
||||||
|
|
||||||
There are several different technologies that could be used to build full color EPDs. The 2 most common ways are to use a color-filter-array (CFA) or use a multi pigment color display.
|
There are several different technologies that could be used to build full-color EPDs. The 2 most common ways are to use a color-filter-array (CFA) or use a multi-pigment color display.
|
||||||
|
|
||||||
The following picture have the multiple pigment color display (ACeP Gallery 3) on the left, and CFA-based color screen (Kaleido Plus) on the right, displaying the same image.
|
The following picture has the multiple pigment color display (ACeP Gallery 3) on the left, and a CFA-based color screen (Kaleido Plus) on the right, displaying the same image.
|
||||||
|
|
||||||
![gallery3_kaleido](assets/gallery3_kaleido_plus.jpg)
|
![gallery3_kaleido](assets/gallery3_kaleido_plus.jpg)
|
||||||
|
|
||||||
|
@ -425,59 +425,63 @@ The following picture have the multiple pigment color display (ACeP Gallery 3) o
|
||||||
|
|
||||||
#### Color Filter Array
|
#### Color Filter Array
|
||||||
|
|
||||||
CFA stands for color filter array, which is basically colored glass/ film on top of the screen pixel. This is also the technology used on most color LCDs. Eink Kaleido, Eink Triton and color DES are based on this technology. The main advantage is that it's relative simple to control, and the low level driving is the same with the greyscale panels. Thus it has the same level of refreshing time (100~200ms), and same level of greyscale (16 level translate to 16^3=4096 colors). The draw back is that the CFA filters out some light (due to its colored nature), the screen reflectivity is negatively affected by the CFA. The screen ends up being quite dark. Up to now, most color E-readers uses CFA-based display. This project supports all three major types of CFA-based EPD screens: color DES screen, Eink Triton, and Eink Kaleido.
|
CFA stands for color filter array, which is colored glass/ film on top of the screen pixel. This is also the technology used on most color LCDs. Eink Kaleido, Eink Triton, and color DES are based on this technology. The main advantage is that it's relatively simple to control, and the low-level driving is the same with the greyscale panels. Thus it has the same level of refreshing time (100~200ms), and the same level of greyscale (16 level translate to 16^3=4096 colors). The drawback is that the CFA filters out some light (due to its colored nature), and the screen reflectivity is negatively affected by the CFA. The screen ends up being quite dark. Up to now, most color E-readers use CFA-based displays. This project supports all three major types of CFA-based EPD screens: color DES screen, Eink Triton, and Eink Kaleido.
|
||||||
|
|
||||||
#### Case Study: GDEW101C01 (CFA-based, DES)
|
#### Case Study: GDEW101C01 (CFA-based, DES)
|
||||||
|
|
||||||
The GDEW101C01 is a 10.1" color DES screen made by Good Display / WeiFeng Tech. It uses CFA to produce color image. As a result, to the eink controller hardware, it's just a normal greyscale panel with bunch of pixels. But the pixels are colored depending on their location due to the CFA. The coloring of the pixels can be either handled by hardware or software.
|
The GDEW101C01 is a 10.1" color DES screen made by Good Display / WeiFeng Tech. It uses CFA to produce color images. As a result, to the eink controller hardware, it's just a normal greyscale panel with a bunch of pixels. However, the pixels are colored depending on their location due to the CFA. The coloring of the pixels can be either handled by hardware or software.
|
||||||
|
|
||||||
##### Pixel Arrangement
|
##### Pixel Arrangement
|
||||||
|
|
||||||
Color DES is a bit different from a typical color TFT LCD in terms of CFA design. Typically on TFT LCDs, one RGB pixel is called a pixel, and each R/G/B component is called as a sub-pixel. On color DES, the sub-pixel is ended up being called as pixel, and each pixel is either red, green, or blue. In display industry, such pixels are more commonly referred as dots.
|
Color DES is a bit different from a typical color TFT LCD in terms of CFA design. Typically on TFT LCDs, one RGB pixel is called a pixel, and each R/G/B component is called as a sub-pixel. On color DES, the sub-pixel ends up being called a pixel, and each pixel is either red, green, or blue. In the display industry, such pixels are more commonly referred to as dots.
|
||||||
|
|
||||||
![subpixel](assets/subpixel.jpg)
|
![subpixel](assets/subpixel.jpg)
|
||||||
|
|
||||||
Pengo, CC BY-SA 3.0 https://creativecommons.org/licenses/by-sa/3.0, via Wikimedia Commons
|
Pengo, CC BY-SA 3.0 https://creativecommons.org/licenses/by-sa/3.0, via Wikimedia Commons
|
||||||
|
|
||||||
The actual photo of DES panel under microscope:
|
The actual photo of the DES panel under the microscope:
|
||||||
|
|
||||||
![color-des](assets/color_des.jpg)
|
![color-des](assets/color_des.jpg)
|
||||||
|
|
||||||
In the above photo, the DES pixel arrangement is the same as the OLPC XO-1.
|
In the above photo, the DES pixel arrangement is the same as the OLPC XO-1.
|
||||||
|
|
||||||
Having no subpixel / each pixel only has 1 color doesn't necessarily mean that the effective resolution needs to be divide by 3. This arrangement is slightly more "efficient" than RGB strip in terms of perceptive resolution. You could find more detailed analysis in the paper Comparing the Effective Resolution of Various RGB Subpixel Layout.
|
Having no subpixel / each pixel only has 1 color doesn't necessarily mean that the effective resolution needs to be divided by 3. This arrangement is slightly more "efficient" than the RGB strip in terms of perceptive resolution. You can find a more detailed analysis in the paper Comparing the Effective Resolution of Various RGB Subpixel Layout.
|
||||||
|
|
||||||
##### Processing image for Color DES
|
##### Processing image for Color DES
|
||||||
|
|
||||||
If the image is displayed on color DES without any processing, it would look like a greyscale image. This is similar when you just send the same color value to R/G/B components on a color LCD display.
|
If the image is displayed on color DES without any processing, it would look like a greyscale image. This is similar to when you just send the same color value to R/G/B components on a color LCD.
|
||||||
|
|
||||||
To get color, send only the color component that correspond to the pixel color.
|
To get color, send only the color component that corresponds to the pixel color.
|
||||||
|
|
||||||
![pixel-layout](assets/PixelLayoutDiagonal.png)
|
![pixel-layout](assets/PixelLayoutDiagonal.png)
|
||||||
(Source: https://wiki.laptop.org/go/File:PixelLayoutDiagonal.png, public domain)
|
(Source: https://wiki.laptop.org/go/File:PixelLayoutDiagonal.png, public domain)
|
||||||
|
|
||||||
For example, for pixel 01, the pixel on the screen is green. Then only the green component from the frame buffer should be sent to the screen.
|
For example, for pixel 01, the pixel on the screen is green. Then only the green component from the frame buffer should be sent to the screen.
|
||||||
|
|
||||||
To get basic 4096 color image display, this is everything needed. However generally to improve image quality, few more steps are applied:
|
To get a basic 4096 color image display, this is everything needed. However generally to improve image quality, a few more steps are applied:
|
||||||
|
|
||||||
##### Low pass filtering
|
##### Low pass filtering
|
||||||
|
|
||||||
The previous described image displaying process is essentially a down-sampling process for each color components: Only 1/3 of the pixel are sent to the screen. Then this becomes a classic signal processing issue: sampling the signal would cause frequency components above Nyquist to fold back to the low frequency part. Or in simpler words, you would see jagged edges/ aliasing, which are things that wasn't present in the original image. To prevent this, low pass filtering (blurring) needs to applied first to the image to remove these high frequency components. The following diagram from OLPC wiki shows a simple way of implementing a such filter:
|
The previously described image-displaying process is essentially a down-sampling process for each color component: Only 1/3 of the pixels are sent to the screen. Then this becomes a classic signal processing issue: sampling the signal would cause frequency components above Nyquist to fold back to the low frequency part. Or in simpler words, you would see jagged edges/ aliasing, which are things that weren't present in the original image. To prevent this, low pass filtering (blurring) needs to be applied first to the image to remove these high-frequency components. The following diagram from the OLPC wiki shows a simple way of implementing a such filter:
|
||||||
|
|
||||||
![pixel-proc](assets/PixelProcDiagonal.png)
|
![pixel-proc](assets/PixelProcDiagonal.png)
|
||||||
(Source: https://wiki.laptop.org/go/File:PixelProcDiagonal.png, public domain)
|
(Source: https://wiki.laptop.org/go/File:PixelProcDiagonal.png, public domain)
|
||||||
|
|
||||||
|
##### Dithering
|
||||||
|
|
||||||
|
Dithering can be applied to further improve image quality. See the dithering section for more details.
|
||||||
|
|
||||||
#### Multi-Pigment Color Display
|
#### Multi-Pigment Color Display
|
||||||
|
|
||||||
Another technology for implemneting color EPD is by using a multi-pigment color display. This is a technology developed initially by SiPix, and further improved by Eink. The basic idea is to use ink particles with different colors inside a single pixel. By applying a sequence of voltages, the ink particles can be arranged to display different colors.
|
Another technology for implementing color EPD is by using a multi-pigment color display. This is a technology developed initially by SiPix and further improved by Eink. The basic idea is to use ink particles with different colors inside a single pixel. By applying a sequence of voltages, the ink particles can be arranged to display different colors.
|
||||||
|
|
||||||
![spectra6](assets/eink_spectra6.jpg)
|
![spectra6](assets/eink_spectra6.jpg)
|
||||||
|
|
||||||
(Source: https://www.eink.com/tech/detail/How_it_works , copyright Eink Corporation)
|
(Source: https://www.eink.com/tech/detail/How_it_works , copyright Eink Corporation)
|
||||||
|
|
||||||
One major advantage of this solution is it can achieve higher resolution (because it doesn't have a CFA, so no resolution reduction), higher reflectivity (because it doesn't have a CFA, so no light loss), and higher color saturation (because it doesn't have a CFA, no need to play the reflectivity vs saturation trade off game).
|
One major advantage of this solution is it can achieve higher resolution (because it doesn't have a CFA, so no resolution reduction), higher reflectivity (because it doesn't have a CFA, so no light loss), and higher color saturation (because it doesn't have a CFA, no need to play the reflectivity vs saturation trade-off game).
|
||||||
|
|
||||||
Eink has 2 lines of products using this Technology, Eink Gallery and Eink Spectra. The advantage is it's much brighter compared to CFA based solutions. The disadvantage is it's much more difficult to drive, and quite slow: 1st /2nd gen Eink Gallery screen takes 30s (!) to refresh, and Spectra 6 Plus devices takes 7s to refresh. It's possible to trade-in some color saturation for higher speed, though still much slower than CFA based solutions. The specific product lines will be discussed in [Eink Screen Generations](#eink-screen-generations)
|
Eink has 2 lines of products using this Technology, Eink Gallery and Eink Spectra. The advantage is it's much brighter compared to CFA-based solutions. The disadvantage is it's much more difficult to drive, and quite slow: 1st /2nd gen Eink Gallery screen takes 30s (!) to refresh, and Spectra 6 Plus devices take 7s to refresh. It's possible to trade in some color saturation for higher speed, though still much slower than CFA-based solutions. The specific product lines will be discussed in [Eink Screen Generations](#eink-screen-generations)
|
||||||
|
|
||||||
##### How ACeP Waveform Works
|
##### How ACeP Waveform Works
|
||||||
|
|
||||||
|
@ -485,50 +489,50 @@ To be written (TODO)
|
||||||
|
|
||||||
##### How to get more colors on ACeP
|
##### How to get more colors on ACeP
|
||||||
|
|
||||||
This is possible with modified waveform.
|
This is possible with a modified waveform.
|
||||||
|
|
||||||
To be written (TODO)
|
To be written (TODO)
|
||||||
|
|
||||||
##### What Happened To ACeP?
|
##### What Happened To ACeP?
|
||||||
|
|
||||||
[ACeP was supposed to the "next big thing" in ereader](https://arstechnica.com/gadgets/2022/04/new-e-ink-gallery-displays-could-finally-make-full-color-e-readers-good/). Back in the end 2022, Eink anounnced that ["Gallery 3 has moved into mass production, with customer products from Bigme, BOOX, iFlyTek, iReader, PocketBook, Readmoo, and AOC coming down the pipeline in 2023 and beyond"](https://www.e-ink-info.com/e-ink-gallery-3-acep-color-epaper-displays-move-mass-production). But 2023 passed with exactly one product, the Bigme Galy, with mixed receptions. Early 2024, it was announced that [Bigme Galy has been discontinued](https://goodereader.com/blog/electronic-readers/bigme-galy-is-discontinued), and [Eink have announced EOL for certain ACeP based products](https://www.ineltek.com/wp-content/uploads/2024/04/EInk_AC073TC1_EOLNoticeLetter_notice_20240401.pdf). It does sound like ACeP is now dead.
|
[ACeP was supposed to be the "next big thing" in ereader](https://arstechnica.com/gadgets/2022/04/new-e-ink-gallery-displays-could-finally-make-full-color-e-readers-good/). Back in the end 2022, Eink announced that ["Gallery 3 has moved into mass production, with customer products from Bigme, BOOX, iFlyTek, iReader, PocketBook, Readmoo, and AOC coming down the pipeline in 2023 and beyond"](https://www.e-ink-info.com/e-ink-gallery-3-acep-color-epaper-displays-move-mass-production). But 2023 passed with exactly one product, the Bigme Galy, with mixed receptions. Early 2024, it was announced that [Bigme Galy has been discontinued](https://goodereader.com/blog/electronic-readers/bigme-galy-is-discontinued), and [Eink has announced EOL for certain ACeP-based products](https://www.ineltek.com/wp-content/uploads/2024/04/EInk_AC073TC1_EOLNoticeLetter_notice_20240401.pdf). It does sound like ACeP is now dead.
|
||||||
|
|
||||||
The following are purely my own speculation. But I see this as 2 separate decisions:
|
The following are purely my speculation. But I see this as 2 separate decisions:
|
||||||
|
|
||||||
- There will be no more multi-pigment based display for eReader market
|
- There will be no more multi-pigment-based displays for the eReader market
|
||||||
- ACeP (CMYW) is being replaced with Spectra 6 (RYBW) in other markets
|
- ACeP (CMYW) is being replaced with Spectra 6 (RYBW) in other markets
|
||||||
|
|
||||||
The second one is evident from the EOL noticed linked previously, the 7.3" ACeP screen has a direct replacement of 7.3" Spectra 6 screen. One major drawback of ACeP in digital signage market (as far as I see) is its inability to reproduce the cyan color. This actually means there is no good way to display blue sky on an ACeP screen, not even through dithering, it's simply outside of its color gamut. By changing the base colors used, Eink was able to mitigate this issue in the Spectra 6 product lines.
|
The second one is evident from the EOL notice linked previously, the 7.3" ACeP screen has a direct replacement of the 7.3" Spectra 6 screen. One major drawback of ACeP in the digital signage market (as far as I see) is its inability to reproduce the cyan color. This actually means there is no good way to display blue sky on an ACeP screen, not even through dithering, it's simply outside of its color gamut. By changing the base colors used, Eink was able to mitigate this issue in the Spectra 6 product lines.
|
||||||
|
|
||||||
The first one is more or less speculation. I have two clues for that. One is the fact that Eink is doubling down on digital signage for Spectra 6: [Both 13.3" and 31.5" Spectra 6 screen will have integrated controller](https://www.beck-elektronik.de/en/newsroom/news/article/e-ink-spectratm-6-der-hingucker-des-jahres-2024). This make them much more interesting for the signage applications, but unsuitable for eReader applications. The other is that [the 8" Spectra 6 Plus screen](https://www.ereaderpro.co.uk/en/blogs/news/e-ink-news-eink-technology-has-unveiled-the-new-generation-of-colour-e-paper-technology-e-ink-spectra-6-plus-designed-for-retail-tags-and-advertising-billboards), while using the same backplane as the Gallery 3 ACeP screen, now quote a 7 second refresh time (compared to less than a second on Gallery 3). If Eink still wanted to make a Spectra 6 eReader screen, this 8" backplane would be the one to use given it was used in ACeP product line.
|
The first one is more or less speculation. I have two clues for that. One is the fact that Eink is doubling down on digital signage for Spectra 6: [Both 13.3" and 31.5" Spectra 6 screens will have integrated controller](https://www.beck-elektronik.de/en/newsroom/news/article/e-ink-spectratm-6-der-hingucker-des-jahres-2024). This make them much more interesting for the signage applications, but unsuitable for eReader applications. The other is that [the 8" Spectra 6 Plus screen](https://www.ereaderpro.co.uk/en/blogs/news/e-ink-news-eink-technology-has-unveiled-the-new-generation-of-colour-e-paper-technology-e-ink-spectra-6-plus-designed-for-retail-tags-and-advertising-billboards), while using the same backplane as the Gallery 3 ACeP screen, now quote a 7 second refresh time (compared to less than a second on Gallery 3). If Eink still wanted to make a Spectra 6 eReader screen, this 8" backplane would be the one to use given it was used in the ACeP product line.
|
||||||
|
|
||||||
Ojectively, ACeP screen on the Bigme Galy pretty much doesn't make any sense anyway. It suffers from poor reflectivity and poor saturation, to a point where it's not much better than Kaleido (see the previous photo). The difference between the Gallery 3 and Gallery Palette (which is supposed to be a lower end product) is also stunning:
|
Objectively, the ACeP screen on the Bigme Galy pretty much doesn't make any sense anyway. It suffers from poor reflectivity and poor saturation to a point where it's not much better than Kaleido (see the previous photo). The difference between Gallery 3 and Gallery Palette (which is supposed to be a lower-end product) is also stunning:
|
||||||
|
|
||||||
![acep_comparison](assets/gallery3_gallerypalette.jpg)
|
![acep_comparison](assets/gallery3_gallerypalette.jpg)
|
||||||
|
|
||||||
(Original illustration copyright MiHoYo)
|
(Original illustration copyright MiHoYo)
|
||||||
|
|
||||||
The one on the left is the Gallery 3 used on eReaders, the one on the right (brighter and more saturated one) is the Gallery Palette used on ESLs. Though to be honest I hacked the right one a bit to display 512 colors opposed to the stock 7 colors. If the Gallery 3 had the same image quality as previous ACeP/ Gallery screens, it would make sense to trade in response time for better image quality. But it doesn't.
|
The one on the left is the Gallery 3 used on eReaders, and the one on the right (brighter and more saturated one) is the Gallery Palette used on ESLs. Though to be honest I hacked the right one a bit to display 512 colors opposed to the stock 7 colors. If Gallery 3 had the same image quality as previous ACeP/ Gallery screens, it would make sense to trade in response time for better image quality. But it doesn't.
|
||||||
|
|
||||||
So is the ACeP dead? Yes and no. Yes in a sense that we are less likely to see any new ACeP products in the future, and we are also unlikely to see any Spectra 6 based eReader products. No in a sense that ACeP is superseded by Spectra 6, so the technology lives on. Just like how the Pearl replaced the Vizplex, and the Carta replaced the Pearl. Now we have Carta so we don't look back to the older generation of screens. Also, in another sense, there are likely at least thousands of ACeP screens already manufactured but didn't made into the consumer devices. We will probably see these screens in the not too distant future!
|
So is the ACeP dead? Yes and no. Yes in the sense that we are less likely to see any new ACeP products in the future, and we are also unlikely to see any Spectra 6-based eReader products. No in the sense that ACeP is superseded by Spectra 6, so the technology lives on. Just like how the Pearl replaced the Vizplex, and the Carta replaced the Pearl. Now we have Carta so we don't look back to the older generation of screens. Also, in another sense, there are likely at least thousands of ACeP screens already manufactured but haven't been made into consumer devices. We will probably see these screens in the not-too-distant future!
|
||||||
|
|
||||||
### Dithering
|
### Dithering
|
||||||
|
|
||||||
Eink and DES panels typically only supports up to 16 level of greyscale with the vendor provided waveform. To improve response time, or to avoid flashing image, binary (1-bit, 2-level) display is also used. Dithering could be applied to produce better image (increasing SNR, in signal processing sense).
|
Eink and DES panels typically only support up to 16 levels of greyscale with the vendor-provided waveform. To improve response time, or to avoid flashing images, a binary (1-bit, 2-level) display is also used. Dithering could be applied to produce better images (increasing SNR, in signal processing sense).
|
||||||
|
|
||||||
The following is applying dithering to a simple black to white gradient. Note the results are not optimal due to limitations in quantization and incorrect gamma correction. But the idea is the same.
|
The following is applying dithering to a simple black-to-white gradient. Note the results are not optimal due to limitations in quantization and incorrect gamma correction. But the idea is the same.
|
||||||
|
|
||||||
| Original | Binary No-dithering | 2 Row Sierra Dithered |
|
| Original | Binary No-dithering | 2 Row Sierra Dithered |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| ![original](assets/grad_orig.png) | ![nodither](assets/grad_no_dither.png) | ![errordiffusion](assets/grad_ed.png) |
|
| ![original](assets/grad_orig.png) | ![nodither](assets/grad_no_dither.png) | ![errordiffusion](assets/grad_ed.png) |
|
||||||
|
|
||||||
Dithering can help when the screen has native 16-level greyscale as well:
|
Dithering can help when the screen has a native 16-level greyscale as well:
|
||||||
|
|
||||||
| Original | 16 Level Greyscale No-dithering | 16 Level Greyscale Dithered |
|
| Original | 16 Level Greyscale No-dithering | 16 Level Greyscale Dithered |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| ![original](assets/grad_orig.png) | ![nodither](assets/grad_4bpp_nd.png) | ![errordiffusion](assets/grad_4bpp_ed.png) |
|
| ![original](assets/grad_orig.png) | ![nodither](assets/grad_4bpp_nd.png) | ![errordiffusion](assets/grad_4bpp_ed.png) |
|
||||||
|
|
||||||
As you can see, the non-dithered image loses all the greyscale in between, while the dithered version on the right gives illusion of greyscale while only using full black and full white colors.
|
As you can see, the non-dithered image loses all the greyscale in between, while the dithered version on the right gives the illusion of greyscale while only using full black and full white colors.
|
||||||
|
|
||||||
To understand it further, take the following example:
|
To understand it further, take the following example:
|
||||||
|
|
||||||
|
@ -540,13 +544,13 @@ This is less than ideal. A better way is to set around 30% of the pixel black, w
|
||||||
|
|
||||||
The ordered dithering adds a pre-computed/ fixed texture to the image before the thresholding process. In other words, it basically adds some noise to the image. This may sound weird initially, but it should be easy to see the effect of noise in the example.
|
The ordered dithering adds a pre-computed/ fixed texture to the image before the thresholding process. In other words, it basically adds some noise to the image. This may sound weird initially, but it should be easy to see the effect of noise in the example.
|
||||||
|
|
||||||
Using the example of previously described displaying 30% brightness grey on a binary screen. The goal is let the rounding process to end up in 0 for 30% of the time, and 1 for 70% of the time. This could be achieved by adding a noise. In the simplest case, a random number with a uniform distribution between [-0.5, 0.5] is added to the incoming brightness. The brightness has a value of 0.3, when adding this number to the random number, the random number now has a uniform distribution between [-0.2, 0.8]. The threshold is still set to 0.5, and now the probability distribution can be seen as below:
|
Using the example previously described displaying 30% brightness grey on a binary screen. The goal is to let the rounding process end up with 0 for 30% of the time and 1 for 70% of the time. This could be achieved by adding a noise. In the simplest case, a random number with a uniform distribution between [-0.5, 0.5] is added to the incoming brightness. The brightness has a value of 0.3, when adding this number to the random number, the random number now has a uniform distribution between [-0.2, 0.8]. The threshold is still set to 0.5, and now the probability distribution can be seen as below:
|
||||||
|
|
||||||
![pdf](assets/dithering_pdf.svg)
|
![pdf](assets/dithering_pdf.svg)
|
||||||
|
|
||||||
The pixel now has 30% chance of being rounded up to 1, and 70% chance of being rounded down to 0. Before dithering, it would always be rounded down to 0.
|
The pixel now has a 30% chance of being rounded up to 1, and a 70% chance of being rounded down to 0. Before dithering, it would always be rounded down to 0.
|
||||||
|
|
||||||
However, purely random number is generally not the best noise to use. Bayer dithering matrix and blue noise are more commonly used, with the results as illustrated below. The idea is the same, but instead of adding random numbers, pre-computed number from the bayer dithering matrix (array) or blue noise texture (array) is added to the image.
|
However, a purely random number is generally not the best noise to use. Bayer dithering matrix and blue noise are more commonly used, with the results as illustrated below. The idea is the same, but instead of adding random numbers, a pre-computed number from the Bayer dithering matrix (array) or blue noise texture (array) is added to the image.
|
||||||
|
|
||||||
| Random Dithering| Bayer Dithering | Blue-noise Dithering |
|
| Random Dithering| Bayer Dithering | Blue-noise Dithering |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
|
@ -554,19 +558,19 @@ However, purely random number is generally not the best noise to use. Bayer dith
|
||||||
|
|
||||||
#### Error-Diffusion Dithering
|
#### Error-Diffusion Dithering
|
||||||
|
|
||||||
The basic idea is when rounding down the color (selecting the closest color from the 16-level greyscale from 256-level input), the error value (difference) is calculated and added to neighboring pixels (so these error would be considered when processing these pixels later). The whole process is called error-diffusion.
|
The basic idea is when rounding down the color (selecting the closest color from the 16-level greyscale from 256-level input), the error value (difference) is calculated and added to neighboring pixels (so this error would be considered when processing these pixels later). The whole process is called error-diffusion.
|
||||||
|
|
||||||
Still using the previous example of 30% brightness image, and assume an extremely simple dither kernel: diffuse all error to the next pixel. Let's see it in action.
|
Still using the previous example of a 30% brightness image, and assume an extremely simple dither kernel: diffuse all error to the next pixel. Let's see it in action.
|
||||||
|
|
||||||
In the first pixel, 0.3 (image brightness) is less than 0.5 (threshold), so it's displayed as 0 (black). This introduce a 0.3 error: the displayed color is 0.3 darker than the requested color. So 0.3 is being diffused to the next pixel, hoping the next pixel can correct the error.
|
In the first pixel, 0.3 (image brightness) is less than 0.5 (threshold), so it's displayed as 0 (black). This introduces a 0.3 error: the displayed color is 0.3 darker than the requested color. So 0.3 is being diffused to the next pixel, hoping the next pixel can correct the error.
|
||||||
|
|
||||||
Onto the second pixel. The value is 0.3 (image brightness) + 0.3 (diffused error) = 0.6. It's now larger than 0.5 (threshold), so it's displayed as 1 (white). This introduces a -0.4 error: the displayed color is 0.4 brighter than the requested color. -0.4 will be diffused to the next pixel.
|
Onto the second pixel. The value is 0.3 (image brightness) + 0.3 (diffused error) = 0.6. It's now larger than 0.5 (threshold), so it's displayed as 1 (white). This introduces a -0.4 error: the displayed color is 0.4 brighter than the requested color. -0.4 will be diffused to the next pixel.
|
||||||
|
|
||||||
The 3rd pixel, the value is now 0.3 - 0.4 = -0.1. This is less than 0.5, and displayed as 0 (black). Error -0.1 is diffused further.
|
For the 3rd pixel, the value is now 0.3 - 0.4 = -0.1. This is less than 0.5 and displayed as 0 (black). Error -0.1 is diffused further.
|
||||||
|
|
||||||
And this process just goes on. With enough pixels, eventually it would yields about 30% of white pixels and 70% of dark pixels.
|
And this process just goes on. With enough pixels, eventually, it would yield about 30% of white pixels and 70% of dark pixels.
|
||||||
|
|
||||||
Similar to how random value is not the best thing to do in ordered dithering, dithering to the right is also less than ideal. It creates very repetitive patterns. I mentioned the word kernel. Error diffusing uses a diffusion kernel, which specifies the target and percentage of the diffused error. There are many classic kernels, such as Floyd–Steinberg, Stucki, and Sierra etc. commonly used for image dithering. They all diffuse to more than 1 pixels to improve the overall look of the image. As shown below, even just diffuse error to 2 pixels (half of the error goes to the pixel on the right, and the rest half of the error goes to the pixel on the bottom) yields much better result:
|
Similar to how random value is not the best thing to do in ordered dithering, dithering to the right is also less than ideal. It creates very repetitive patterns. I mentioned the word kernel. Error diffusing uses a diffusion kernel, which specifies the target and percentage of the diffused error. There are many classic kernels, such as Floyd-Steinberg, Stucki, Sierra, etc. commonly used for image dithering. They all diffuse to more than 1 pixel to improve the overall look of the image. As shown below, even just diffusing the error to 2 pixels (half of the error goes to the pixel on the right, and the rest half of the error goes to the pixel on the bottom) yields a much better result:
|
||||||
|
|
||||||
| Dither to Right | Right and Down | Floyd-Steinberg |
|
| Dither to Right | Right and Down | Floyd-Steinberg |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
|
@ -575,34 +579,34 @@ Similar to how random value is not the best thing to do in ordered dithering, di
|
||||||
|
|
||||||
#### Applying Dithering on CFA-based Color Screens
|
#### Applying Dithering on CFA-based Color Screens
|
||||||
|
|
||||||
Dithering can be applied on CFA-based color screens such as Eink Kaleido and color DES screens as well. The following is on a simulated DES screen: (left original is assuming screen has native 24bpp color, still on a simulated screen)
|
Dithering can be applied on CFA-based color screens such as Eink Kaleido and color DES screens as well. The following is on a simulated DES screen: (The left original is assuming the screen has a native 24bpp color, still on a simulated screen)
|
||||||
|
|
||||||
| 16M color DES (does not exist) | 8-color DES | 8-color DES Dithered |
|
| 16M color DES (does not exist) | 8-color DES | 8-color DES Dithered |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| ![original](assets/color_8bpp.png) | ![nodither](assets/color_nd.png) | ![errordiffusion](assets/color_ed.png) |
|
| ![original](assets/color_8bpp.png) | ![nodither](assets/color_nd.png) | ![errordiffusion](assets/color_ed.png) |
|
||||||
|
|
||||||
Ordinary dithering kernels don't work too well on color screens. For example, the error-diffusion dithering process pushes/ diffuses error neighboring pixels without considering their color. Ideally it should push/ diffuse the error only to pixels with the same color. This is fairly easy to fix though, by tweaking the kernel it would achieve good results on CFA-based screens as well. (I am going to shamelessly call it Wenting's kernel)
|
Ordinary dithering kernels don't work too well on color screens. For example, the error-diffusion dithering process pushes/ diffuses error neighboring pixels without considering their color. Ideally, it should push/ diffuse the error only to pixels with the same color. This is fairly easy to fix though, by tweaking the kernel it would achieve good results on CFA-based screens as well. (I am going to shamelessly call it Wenting's kernel)
|
||||||
|
|
||||||
| 16M color DES (does not exist) | 8-color DES naively apply Floyd-Steinberg (wrong) | 8-color DES with Wenting's kernel |
|
| 16M color DES (does not exist) | 8-color DES naively apply Floyd-Steinberg (wrong) | 8-color DES with Wenting's kernel |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| ![original](assets/color_8bpp.png) | ![original](assets/color_fs_wrong.png) | ![errordiffusion](assets/color_ed.png) |
|
| ![original](assets/color_8bpp.png) | ![original](assets/color_fs_wrong.png) | ![errordiffusion](assets/color_ed.png) |
|
||||||
|
|
||||||
|
|
||||||
Of course one can apply bayer-like ordered dithering, blue noise dithering, or dithering on 4096-color mode as well:
|
Of course, one can apply Bayer-like ordered dithering, blue noise dithering, or dithering on 4096-color mode as well:
|
||||||
|
|
||||||
| 8-color DES Bayer-like | 8-color DES Blue-noise | 4096-color DES Error-diffusion |
|
| 8-color DES Bayer-like | 8-color DES Blue-noise | 4096-color DES Error-diffusion |
|
||||||
|-|-|-|
|
|-|-|-|
|
||||||
| ![original](assets/color_bayer.png) | ![original](assets/color_bn.png) | ![errordiffusion](assets/color_4bpp_ed.png) |
|
| ![original](assets/color_bayer.png) | ![original](assets/color_bn.png) | ![errordiffusion](assets/color_4bpp_ed.png) |
|
||||||
|
|
||||||
It's called bayer because, similar to how naively doing error diffusion doesn't work, the bayer matrix has to be modified to work on color screen.
|
It's called bayer because, similar to how naively doing error diffusion doesn't work, the bayer matrix has to be modified to work on the color screen.
|
||||||
|
|
||||||
#### Gamma Correction
|
#### Gamma Correction
|
||||||
|
|
||||||
Another thing to consider is gamma. The dithering process involves a step of selecting the closest value. However, selecting the closest numerical value is not necessarily mean the closest color. The image typically is in sRGB space, which is non-linear. This causes the simple rounding to pick the wrong color, also calculating the wrong error value. One solution is to work in the linear space. This is also known as gamma-aware dithering. You could read more related info online, for example here: [https://learnopengl.com/Advanced-Lighting/Gamma-Correction](https://learnopengl.com/Advanced-Lighting/Gamma-Correction).
|
Another thing to consider is gamma. The dithering process involves a step of selecting the closest value. However, selecting the closest numerical value does not necessarily mean the closest color. The image typically is in sRGB space, which is non-linear. This causes the simple rounding to pick the wrong color, also calculating the wrong error value. One solution is to work in the linear space. This is also known as gamma-aware dithering. You could read more related info online, for example here: [https://learnopengl.com/Advanced-Lighting/Gamma-Correction](https://learnopengl.com/Advanced-Lighting/Gamma-Correction).
|
||||||
|
|
||||||
![dither-gamma](assets/dither_gamma.jpg)
|
![dither-gamma](assets/dither_gamma.jpg)
|
||||||
|
|
||||||
The difference is quite evident when dithering down to 1 bit for color screen. Top left is the original image, top right is dithering in the sRGB space, while bottom left is dithering in the linear space.
|
The difference is quite evident when dithering down to 1 bit for a color screen. The top left is the original image, the top right is dithering in the sRGB space, and the bottom left is dithering in the linear space.
|
||||||
|
|
||||||
#### Further Reading
|
#### Further Reading
|
||||||
|
|
||||||
|
@ -614,36 +618,48 @@ Depending on how you count, there are multiple generations of Eink screens comme
|
||||||
|
|
||||||
![eink_serial](assets/eink_serial.jpg)
|
![eink_serial](assets/eink_serial.jpg)
|
||||||
|
|
||||||
And use the following table:
|
That is the FPL code in the following table:
|
||||||
|
|
||||||
| FPL Platform | FPL Code | Marketing Name | First Introduced |
|
| FPL Platform | FPL Code | Panel Model | Marketing Name | First Introduced |
|
||||||
| ------------ | -------- | ----------------------- | ---------------- |
|
| ------------ | -------- | -------------- | ----------------------- | ---------------- |
|
||||||
| 2.0 | 0 | | 2004 |
|
| 2.0 | 0 | | | ? |
|
||||||
| 2.1 | 1 | | ? |
|
| 2.1 | 1 | | | 2004 |
|
||||||
| 2.3 | 2 | | ? |
|
| 2.3 | 2 | | | ? |
|
||||||
| V100 | 3 | Vizplex | 2007 |
|
| V100 | 3 | | Vizplex | 2007 |
|
||||||
| V110 | 4 | Vizplex | 2008 |
|
| V110 | 4 | | Vizplex | 2008 |
|
||||||
| V110A | 5 | Vizplex | 2008 |
|
| V110A | 5 | | Vizplex | 2008 |
|
||||||
| V220 | 6 | Pearl | 2010 |
|
| V220 | 6 | VA3200 | Pearl | 2010 |
|
||||||
| V250 | 7 | Pearl | ? |
|
| V250 | 7 | | Pearl | ? |
|
||||||
| V220E | 8 | Pearl | ? |
|
| V220E | 8 | | Pearl | ? |
|
||||||
| V320 | 9, R | Carta 1.2 / 1000 / 1100 | 2013 |
|
| V320 | 9, R | VB3300 | Carta 1.2 / 1000 | 2013 |
|
||||||
| V400 | A, C | Roadrunner / Carta 1200 | 2021 |
|
| V320 | ? | VB3300? | Carta 1100 | 2019 |
|
||||||
| V450 | | Carta 1250 | ? |
|
| V400 | A, C | VD1400/ VD1405 | Roadrunner / Carta 1200 | 2021 |
|
||||||
| ? | | Carta 1300 | 2023 |
|
| V450 | ? | VH1948 | Carta 1250 | 2021? |
|
||||||
|
| ? | ? | VD1405 | Carta 1300 | 2023 |
|
||||||
|
|
||||||
I will let you to decide how to count the generations.
|
Data points used to create the table above:
|
||||||
|
- The first commercialized Eink e-reader SONY Librie hit the market in 2004, *likely* with an ED060SC1 panel
|
||||||
|
- ED060SC1 has an FPL code of 1 on the barcode, meaning the 2.1 platform
|
||||||
|
- Multiple datasheets (like the one for ED060SC4) confirms the 6th digit marks the FPL code with mapping for V220/220E/320/400
|
||||||
|
- Inkwave's WBF decoder (originated from Kindle GPL kernel code) provides an FPL platform to an FPL code mapping table that matches well with info from the datasheet
|
||||||
|
- Kindle Oasis3 was reported to use a Carta 1100 screen, and it has an ED070KC3 screen with a V320 FPL platform
|
||||||
|
- Kindle PW5 was reported to use a Carta 1200 screen, and it has an ED068KC5 with a VD1405 panel model
|
||||||
|
- Kobo Clara BW was reported to use a Carta 1300 screen, and it has an ED060KHE with a VD1405 panel model
|
||||||
|
- The datasheet of ED068KC1 mentioned the name "Roadrunner" for the 400 platform, but that name never gets used outside of that. I would guess they were going to use the Roadrunner for the new generation but eventually fell back to Carta 1200 so it's more like an incremental improvement
|
||||||
|
- From the information available, it really looks like Carta 1000 and 1100 use the same film, and Carta 1200 and 1300 use the same film. If this is true, it may sound like a scam if they are named differently but use the same film. But this is actually okay. Just like how chips usually have a binning process, the same chip would sell under different product names with different performance levels. It's reasonable for Eink to do incremental improvements on the manufacturing process to yield better screens with the same film and call it under a different name, or simply binning screens to different grades and selling under different names.
|
||||||
|
|
||||||
|
I will let you decide how to count the generations.
|
||||||
|
|
||||||
For the CFA-based screens, the following generations of screens exist:
|
For the CFA-based screens, the following generations of screens exist:
|
||||||
|
|
||||||
- Eink Triton: First generation color screen. Uses RGBW glass color filter and square pixel. Underlying screen panel uses Pearl film.
|
- Eink Triton: First generation color screen. Uses an RGBW glass color filter and square pixels. The underlying screen panel uses Pearl film.
|
||||||
- Eink Triton 2: 2nd generation color screen. Uses RGB glass color filter and stripe pixel. Underlying screen panel uses Pearl film.
|
- Eink Triton 2: 2nd generation color screen. Uses RGB glass color filter and stripe pixel. The underlying screen panel uses Pearl film.
|
||||||
- Eink Kaleido: 3rd or 2nd gen color screen depending on the definition. Uses RGB color filter. Each pixel is still square, but each color covers 3 pixels. Underlying screen panel uses Carta film.
|
- Eink Kaleido: 3rd or 2nd gen color screen depending on the definition. Uses an RGB color filter. Each pixel is still square, but each color covers 3 pixels. The underlying screen panel uses Carta film.
|
||||||
- Eink Kaleido Plus: 2nd gen Kaleido. Uses RGB color filter. Each pixel is still square but different configurations exist. Some screens has each color covering 2 pixels, some others have each color covering only 1 pixel. Underlying screen panel uses Carta film.
|
- Eink Kaleido Plus: 2nd gen Kaleido. Uses an RGB color filter. Each pixel is still square but different configurations exist. Some screens have each color covering 2 pixels, some others have each color covering only 1 pixel. The underlying screen panel uses Carta film.
|
||||||
- Eink Kaleido 3: 3rd gen Kaleido. Exists many different configurations, ranging from RGBW filter covering 1 pixel per color, to RGB filter covering 3 pixels per color more like the original Kaleido. Underlying screen panel uses Carta 1000/1200/1250/1300 film depending on the model.
|
- Eink Kaleido 3: 3rd gen Kaleido. There are many different configurations, ranging from RGBW filter covering 1 pixel per color, to RGB filter covering 3 pixels per color more like the original Kaleido. The underlying screen panel uses Carta 1000/1200/1250/1300 film depending on the model.
|
||||||
- Eink Kaleido 3 Outdoor: Wide temperature version of Kaleido 3.
|
- Eink Kaleido 3 Outdoor: Wide temperature version of Kaleido 3.
|
||||||
|
|
||||||
As far as I know, all CFA-based color screen panels don't come with integrated controller.
|
As far as I know, all CFA-based color screen panels don't come with an integrated controller.
|
||||||
|
|
||||||
For the multiple-pigment color screens based on SiPix technology, the following generations of screens exist:
|
For the multiple-pigment color screens based on SiPix technology, the following generations of screens exist:
|
||||||
|
|
||||||
|
@ -651,20 +667,20 @@ For the multiple-pigment color screens based on SiPix technology, the following
|
||||||
|
|
||||||
- Eink Spectra 3000: BWR or BWY 3 color screen.
|
- Eink Spectra 3000: BWR or BWY 3 color screen.
|
||||||
- Eink Spectra 3100: BWRY 4 color screen.
|
- Eink Spectra 3100: BWRY 4 color screen.
|
||||||
- Eink Spectra 3100 Plus:BWRY 4 color screen. Orange display is now possible with driver circuit changes
|
- Eink Spectra 3100 Plus: BWRY 4 color screen. The orange display is now possible with driver circuit changes
|
||||||
- Eink Spectra 6: RYBW 4 color screen. Can reproduce 6 different colors by mixing colors
|
- Eink Spectra 6: RYBW 4 color screen. Can reproduce 6 different colors by mixing colors
|
||||||
- Eink Spectra 6 Plus: RYBW 4 color screen. Still reproduce 6 different colors. Allows faster refresh compare to 6 with driver circuit changes
|
- Eink Spectra 6 Plus: RYBW 4 color screen. Still reproduces 6 different colors. Allows faster refresh compared to 6 with driver circuit changes
|
||||||
- Eink Gallery: CMYW 4 color screen (ACeP).
|
- Eink Gallery: CMYW 4 color screen (ACeP).
|
||||||
- Eink Gallery Plus: CMYW 4 color screen (ACeP).
|
- Eink Gallery Plus: CMYW 4 color screen (ACeP).
|
||||||
- Eink Gallery Palette: CMYW 4 color screen (ACeP). Reproduce 7 different colors.
|
- Eink Gallery Palette: CMYW 4 color screen (ACeP). Reproduce 7 different colors.
|
||||||
- Eink Gallery 3: CMYW 4 color screen (ACeP). Reproduce 12 different colors, much faster than other Gallery screens at the cost of lower saturation and lowr reflectivity
|
- Eink Gallery 3: CMYW 4 color screen (ACeP). Reproduce 12 different colors, much faster than other Gallery screens at the cost of lower saturation and lower reflectivity
|
||||||
|
|
||||||
There are both integrated-controller Spectra/Gallery screens and controller-less Spectra/Gallery screens.
|
There are both integrated-controller Spectra/Gallery screens and controller-less Spectra/Gallery screens.
|
||||||
|
|
||||||
Additional notes regarding the multi-pigment color screens:
|
Additional notes regarding the multi-pigment color screens:
|
||||||
|
|
||||||
- ACeP, or Advanced Color ePaper refers to the CMYW 4 color screen. Is not a product line on its own
|
- ACeP, or Advanced Color ePaper refers to the CMYW 4 color screen. Is not a product line on its own
|
||||||
- To be honest, I don't know how many colors can be reproduced on Gallery or Gallery Plus screens based on public information. Eink claims 30000 or 60000 colors in their materials, but they also clarified these numbers refers to color gamut. In other words, they represent color saturation rather than number of different colors can be displayed on screen. Dithering is heavily used to display color image on Gallery screens.
|
- To be honest, I don't know how many colors can be reproduced on Gallery or Gallery Plus screens based on public information. Eink claims 30000 or 60000 colors in their materials, but they also clarified these numbers refer to color gamut. In other words, they represent color saturation rather than a number of different colors that can be displayed on screen. Dithering is heavily used to display color images on Gallery screens.
|
||||||
- It's possible to achieve more colors on Gallery Palette screens. 7 is not a physical limit.
|
- It's possible to achieve more colors on Gallery Palette screens. 7 is not a physical limit.
|
||||||
|
|
||||||
## Design of Caster and Glider
|
## Design of Caster and Glider
|
||||||
|
@ -681,30 +697,30 @@ The top-level design has 3 major clock domains: clk_vi: Input video clock domain
|
||||||
|
|
||||||
To understand how it works, the following is a guided tour around the life cycle of a pixel.
|
To understand how it works, the following is a guided tour around the life cycle of a pixel.
|
||||||
|
|
||||||
Before an incoming pixel can be processed by the controller, the memif module needs to retrieve the local pixel state from the DDR SDRAM. Once the value is retrieved, it’s pushed into the state readout/ input FIFO (bi_fifo). At/ around the same time, input video stream is pushed into the video input FIFO (vi_fifo).
|
Before an incoming pixel can be processed by the controller, the memif module needs to retrieve the local pixel state from the DDR SDRAM. Once the value is retrieved, it’s pushed into the state readout/ input FIFO (bi_fifo). At/ around the same time, the input video stream is pushed into the video input FIFO (vi_fifo).
|
||||||
|
|
||||||
The EPDC runs a local Eink timing generator for counting pixels and blankings. This timing should be a slightly delayed version of the incoming video timing. Once the local timing generator determines that it needs to output the pixel soon, the EPDC logic pops out one pair of the video input and state readout and starts processing.
|
The EPDC runs a local Eink timing generator for counting pixels and blankings. This timing should be a slightly delayed version of the incoming video timing. Once the local timing generator determines that it needs to output the pixel soon, the EPDC logic pops out one pair of the video input and state readout and starts processing.
|
||||||
Two values goes through the video processing pipeline:
|
Two values go through the video processing pipeline:
|
||||||
|
|
||||||
- Stage 1: This pipeline stage waits for the FIFO to output the data.
|
- Stage 1: This pipeline stage waits for the FIFO to output the data.
|
||||||
- Stage 2: The 8-bit input image is dithered down to 1-bit and 4-bit at this stage for later use.
|
- Stage 2: The 8-bit input image is dithered down to 1-bit and 4-bit at this stage for later use.
|
||||||
- Stage 3: The waveform lookup is done at this stage for 16-level grayscale modes
|
- Stage 3: The waveform lookup is done at this stage for 16-level grayscale modes
|
||||||
- Stage 4: Based on the pixel state, new state and voltage selection value is determined at this stage.
|
- Stage 4: Based on the pixel state, the new state and voltage selection value are determined at this stage.
|
||||||
- Stage 5: New state is pushed into the state writeback/ out FIFO (bo_fifo) and the voltage selection is sent to the screen.
|
- Stage 5: The new state is pushed into the state writeback/ out FIFO (bo_fifo) and the voltage selection is sent to the screen.
|
||||||
|
|
||||||
The memif module later pops out the writeback value from the bo_fifo and writes back to the DDR SDRAM.
|
The memif module later pops out the writeback value from the bo_fifo and writes it back to the DDR SDRAM.
|
||||||
|
|
||||||
The EPDC always processes 4 pixels per clock. For screens with different interface width, a rate adapter is added after the EPDC output. Some logic are duplicated 2 or 4 times (such as the waveform RAM or the pixel decision logic), while some are extended and daisy-chained (such as the error diffusion dithering unit) to achieve the 4 pixels per clock throughput.
|
The EPDC always processes 4 pixels per clock. For screens with different interface widths, a rate adapter is added after the EPDC output. Some logic is duplicated 2 or 4 times (such as the waveform RAM or the pixel decision logic), while some are extended and daisy-chained (such as the error diffusion dithering unit) to achieve the 4 pixels per clock throughput.
|
||||||
|
|
||||||
### Firmware Functions
|
### Firmware Functions
|
||||||
|
|
||||||
The MCU manages house-keeping items as described below. It currently doesn’t use any operating system, but rather relying on a main-loop style operation.
|
The MCU manages housekeeping items as described below. It currently doesn’t use any operating system but rather relies on a main-loop style operation.
|
||||||
|
|
||||||
- EPD Power Supply: The power supply provides common, source, and gate supply to the EPD panel. In addition to basic on/off switch, the MCU can also adjust the VCOM voltage, and measure the optimal VCOM voltage of the panel installed. The VCOM measurement is done by isolating the VCOM supply from the screen with keeping the gate supply, scan the screen with source = VCOM, and measure the kick-back voltage on VCOM.
|
- EPD Power Supply: The power supply provides a common, source, and gate supply to the EPD panel. In addition to a basic on/off switch, the MCU can also adjust the VCOM voltage, and measure the optimal VCOM voltage of the panel installed. The VCOM measurement is done by isolating the VCOM supply from the screen while keeping the gate supply, scanning the screen with source = VCOM, and measuring the kick-back voltage on the VCOM.
|
||||||
- FPGA Bitstream Loading: The FPGA doesn’t have its own flash memory, the bitstream is pushed over SPI from the MCU to the FPGA upon powering up. In this way the FPGA bitstream can be easily bundled together with the MCU’s firmware and updated together.
|
- FPGA Bitstream Loading: The FPGA doesn’t have its own flash memory, the bitstream is pushed over SPI from the MCU to the FPGA upon powering up. In this way, the FPGA bitstream can be easily bundled together with the MCU’s firmware and updated together.
|
||||||
- Type-C Negotiation: The on-board USB Type-C port can support video input in addition to powering the board using the USB-C DisplayPort Alt Mode. The MCU runs a USB-C PD stack to communicate this capability to the video source device over standard USB PD protocol. The MCU also controls the Type-C signal mux to remap the lanes to the correct place depending on the cable orientation.
|
- Type-C Negotiation: The onboard USB Type-C port can support video input in addition to powering the board using the USB-C DisplayPort Alt Mode. The MCU runs a USB-C PD stack to communicate this capability to the video source device over standard USB PD protocol. The MCU also controls the Type-C signal mux to remap the lanes to the correct place depending on the cable orientation.
|
||||||
- Video decoder initialization: The FPGA used on the board doesn’t have high speed deserializers to interface with common high speed video interface such as DisplayPort or DVI directly. Instead, dedicated video decoder chips are used on the board. They typically needs initialization before use, and the MCU takes care of this. In this specific design the DP decoder chip also handles AUX P/N line flipping based on the Type-C cable orientation.
|
- Video decoder initialization: The FPGA used on the board doesn’t have high-speed deserializers to interface with common high-speed video interfaces such as DisplayPort or DVI directly. Instead, dedicated video decoder chips are used on the board. They typically need initialization before use, and the MCU takes care of this. In this specific design, the DP decoder chip also handles AUX P/N line flipping based on the Type-C cable orientation.
|
||||||
- PC communication: One advantage of the Caster is that update modes and forced update/ clearing can be applied on a per-pixel basis. Software may utilize this to assign different modes to different windows or change update modes depending on the content on the fly. This is done by sending requests to the MCU over USB connection. The MCU runs TinyUSB and present itself as an HID device so it can forward messages between the hos PC and the FPGA.
|
- PC communication: One advantage of the Caster is that update modes and forced update/ clearing can be applied on a per-pixel basis. Software may utilize this to assign different modes to different windows or change update modes depending on the content on the fly. This is done by sending requests to the MCU over a USB connection. The MCU runs TinyUSB and presents itself as an HID device so it can forward messages between the host PC and the FPGA.
|
||||||
|
|
||||||
### Low Latency Drive
|
### Low Latency Drive
|
||||||
|
|
||||||
|
@ -712,29 +728,29 @@ The Caster implements several techniques for reducing the latency, which will be
|
||||||
|
|
||||||
As described before, the existing basic driving method employs a global counter for looking up the waveform table. This imposes a limit on the global image update rate: the controller only accepts a new incoming image after the previous update is finished. The update usually takes about 100ms, translating to an image rate of 10Hz. Or, in other words, the user needs to potentially wait up to 100ms before the new image is even processed by the controller.
|
As described before, the existing basic driving method employs a global counter for looking up the waveform table. This imposes a limit on the global image update rate: the controller only accepts a new incoming image after the previous update is finished. The update usually takes about 100ms, translating to an image rate of 10Hz. Or, in other words, the user needs to potentially wait up to 100ms before the new image is even processed by the controller.
|
||||||
|
|
||||||
One way to mitigate this issue is by having multiple update regions. For example, imagine the user is typing a and b. In a single region controller design, a is being drawn to the screen immediately, while the b needs to wait 100ms before it gets drawn. If the controller supports multiple regions, it could start drawing the letter b as soon as it’s typed, reducing the latency. This however requires the software to program the controller to correctly set the region to the letter boundary, and re-allocating regions on the fly as the number of regions is generally quite limited (like 4-16).
|
One way to mitigate this issue is by having multiple update regions. For example, imagine the user is typing a and b. In a single region controller design, a is drawn to the screen immediately, while the b needs to wait 100ms before it gets drawn. If the controller supports multiple regions, it could start drawing the letter b as soon as it’s typed, reducing the latency. This however requires the software to program the controller to correctly set the region to the letter boundary, and re-allocating regions on the fly as the number of regions is generally quite limited (like 4-16).
|
||||||
|
|
||||||
![caster-pipelined](assets/caster_pipelined_update.svg)
|
![caster-pipelined](assets/caster_pipelined_update.svg)
|
||||||
|
|
||||||
The Caster simply treats every pixel as an individual update region, for maximum flexibility and is transparent to the software.
|
The Caster simply treats every pixel as an individual update region, for maximum flexibility and is transparent to the software.
|
||||||
|
|
||||||
Another latency optimization technique the Caster implemented is on the pixel that’s already being updated. For example, if the user types the letter a and deletes it right after. With the basic driving method, the controller needs to wait till the letter a is fully displayed before it can erase it. The previously proposed/ implemented regional update doesn’t help here because in this situation it’s about the same pixel so it has to be in the same region. The second technique is early cancellation. If a pixel changes before it’s fully driven, instead of waiting for it to be fully driven, it’s driven towards the requested input state, and the frame counter is updated depending on the newly calculated driving time.
|
Another latency optimization technique the Caster implemented is on the pixel that’s already being updated. For example, if the user types the letter a and deletes it right after. With the basic driving method, the controller needs to wait till the letter a is fully displayed before it can erase it. The previously proposed/ implemented regional update doesn’t help here because in this situation it’s about the same pixel so it has to be in the same region. The second technique is early cancellation. If a pixel changes before it’s fully driven, instead of waiting for it to be fully driven, it’s driven toward the requested input state, and the frame counter is updated depending on the newly calculated driving time.
|
||||||
|
|
||||||
![caster-early-cancel](assets/caster_early_cancel.svg)
|
![caster-early-cancel](assets/caster_early_cancel.svg)
|
||||||
|
|
||||||
By combining both, it’s then possible to implement low latency binary and 4-level grayscale modes. The tradeoff between framerate and contrast ratio is also no longer relevant. Both high frame rate and high contrast ratio are achieved automatically.
|
By combining both, it’s then possible to implement low-latency binary and 4-level grayscale modes. The tradeoff between framerate and contrast ratio is also no longer relevant. Both a high frame rate and high contrast ratio are achieved automatically.
|
||||||
|
|
||||||
### Hybrid Greyscale Mode
|
### Hybrid Greyscale Mode
|
||||||
|
|
||||||
As discussed previously, getting [greyscale](#greyscale-display) image on Eink is a sophiscated process, much slower than binary, and shows flashing images during the process. This pose challenges on how to make it useful for the users.
|
As discussed previously, getting [greyscale](#greyscale-display) image on Eink is a sophisticated process, much slower than binary, and shows flashing images during the process. This poses challenges on how to make it useful for the users.
|
||||||
|
|
||||||
On eReaders, the software could switch between fast and slow modes based on the action. The eReader software may also simply not support things that doesn’t work well on the screen. For example, there might be no scrolling but only whole page flipping. What’s being done on existing eink monitors is throwing the problem back to the user. The user simply need to accept that update is slow, latency is long, and the process is flashing.
|
On eReaders, the software could switch between fast and slow modes based on the action. The eReader software may also simply not support things that don’t work well on the screen. For example, there might be no scrolling but only whole page flipping. What’s being done on existing eink monitors is throwing the problem back to the user. The user simply needs to accept that the update is slow, the latency is long, and the process is flashing.
|
||||||
|
|
||||||
What Caster implemented is allowing it to switch between the fast binary mode and slow greyscale mode automatically on a per pixel basis. When the input image is changed, it switches to binary mode and do the update. When the image hasn’t changed for a while, it re-renders the image in greyscale.
|
What Caster implemented is allowing it to switch between the fast binary mode and slow greyscale mode automatically on a per-pixel basis. When the input image is changed, it switches to binary mode and does the update. When the image hasn’t changed for a while, it re-renders the image in greyscale.
|
||||||
|
|
||||||
### Limitations
|
### Limitations
|
||||||
|
|
||||||
The method does come with downsides: it requires much more memory bandwidth to implement. Taking a 1080P panel as an example (roughly 120 Mp/s (million pixels per second) with reduced blanking). With the traditional method, the controller only needs the old pixel state and the new pixel state (4bpp each) to determine the voltage needed, or 8-bit/ 1-byte memory read per pixel. The bandwidth requirement is then 120Mp/s x 1B/pixel = 120MB/s. One single 16-bit SDR-133 SDRAM is more than enough to handle this. The Caster currently stores 16bit state per pixel (for 2 sets of old pixel values and pixel specific timer counters), and the pixel state needs to be updated per frame, so pixel state buffer alone requires 2-byte read and 2-byte write per pixel. It then takes another 0.5-byte per pixel to read the new image value from memory. 120Mp/s x 4.5B/pixel = 540MB/s. A 16-bit DDR-333 memory is then needed to implement this. The Glider hardware uses a DDR3-800 memory to allow even higher resolution. If the controller is not integrated inside an SoC (like our case, the controller is sitting inside the monitor, not part of your PC’s CPU/GPU), it also needs to use actual low latency video interfaces like DVI or DP, instead of simpler but slower interfaces like USB or I80/SPI. This could drive up cost as well. These techniques also don't help with use cases like reading books, so commercial ereader solutions have little reason to spend the extra trouble to implement these.
|
The method does come with downsides: it requires much more memory bandwidth to implement. Taking a 1080P panel as an example (roughly 120 Mp/s (million pixels per second) with reduced blanking). With the traditional method, the controller only needs the old pixel state and the new pixel state (4bpp each) to determine the voltage needed or 8-bit/ 1-byte memory read per pixel. The bandwidth requirement is then 120Mp/s x 1B/pixel = 120MB/s. One single 16-bit SDR-133 SDRAM is more than enough to handle this. The Caster currently stores a 16-bit state per pixel (for 2 sets of old pixel values and pixel-specific timer counters), and the pixel state needs to be updated per frame, so the pixel state buffer alone requires 2-byte read and 2-byte write per pixel. It then takes another 0.5-byte per pixel to read the new image value from memory. 120Mp/s x 4.5B/pixel = 540MB/s. A 16-bit DDR-333 memory is then needed to implement this. The Glider hardware uses a DDR3-800 memory to allow even higher resolution. If the controller is not integrated inside an SoC (like our case, the controller is sitting inside the monitor, not part of your PC’s CPU/GPU), it also needs to use actual low latency video interfaces like DVI or DP, instead of simpler but slower interfaces like USB or I80/SPI. This could drive up costs as well. These techniques also don't help with use cases like reading books, so commercial e-reader solutions have little reason to spend the extra trouble to implement these.
|
||||||
|
|
||||||
### Hardware Design Decisions
|
### Hardware Design Decisions
|
||||||
|
|
||||||
|
@ -742,7 +758,7 @@ To be written (TODO)
|
||||||
|
|
||||||
### Resources Utilization
|
### Resources Utilization
|
||||||
|
|
||||||
The following number are for reference only and would vary depending on RTL options and specific target.
|
The following numbers are for reference only and would vary depending on RTL options and specific targets.
|
||||||
|
|
||||||
- 1704 FF
|
- 1704 FF
|
||||||
- 2531 LUT6
|
- 2531 LUT6
|
||||||
|
@ -754,7 +770,7 @@ The following number are for reference only and would vary depending on RTL opti
|
||||||
|
|
||||||
The PCB is designed with KiCAD 8.0. To get optimal results, use a 4-layer stack up with 1080 PP layers, but 2313 or 3313 are also acceptable.
|
The PCB is designed with KiCAD 8.0. To get optimal results, use a 4-layer stack up with 1080 PP layers, but 2313 or 3313 are also acceptable.
|
||||||
|
|
||||||
There are 2 versions of the mainboard, one full version and a lite version. For now only the full version is being actively worked on. The lite version removes dedicated external decoders for DVI/ DP and removes bulk of the TypeC circuitry to lower the cost. The only video interface being a DVI port feeding directly into the FPGA.
|
There are 2 versions of the mainboard, one full version, and a lite version. For now, only the full version is being actively worked on. The lite version removes dedicated external decoders for DVI/ DP and removes the bulk of the TypeC circuitry to lower the cost. The only video interface is a DVI port feeding directly into the FPGA.
|
||||||
|
|
||||||
### FPGA Bitstream
|
### FPGA Bitstream
|
||||||
|
|
||||||
|
@ -766,7 +782,7 @@ To be written (TODO)
|
||||||
|
|
||||||
### Working with Waveforms
|
### Working with Waveforms
|
||||||
|
|
||||||
The following section describes the waveform file format and how to use them.
|
The following section describes the waveform file format and how to use it.
|
||||||
|
|
||||||
#### Obtaining Waveform
|
#### Obtaining Waveform
|
||||||
|
|
||||||
|
@ -776,11 +792,11 @@ If your screen has a flash chip on it, it's also possible to extract the wavefor
|
||||||
|
|
||||||
```dd if=somedump.bin of=waveform.wbf bs=1 skip=2182```
|
```dd if=somedump.bin of=waveform.wbf bs=1 skip=2182```
|
||||||
|
|
||||||
If you have access to an application board, it might also be possible to extract the waveform there. For example, if the system uses T1000 controller, the waveform is usually stored in the SPI flash connected to the T1000.
|
If you have access to an application board, it might also be possible to extract the waveform there. For example, if the system uses a T1000 controller, the waveform is usually stored in the SPI flash connected to the T1000.
|
||||||
|
|
||||||
#### Waveform Formats
|
#### Waveform Formats
|
||||||
|
|
||||||
E-Ink distribute waveforms in the wbf file format. SoC/ Eink controller hardware often require converting the file into vendor-specific file format. Caster/ Glider also uses a specific binary format. This project defines a common human-readable format (Interchangeable Waveform Format, IWF) and provides several tools for working with different binary formats and the IWF format.
|
E-Ink distributes waveforms in the wbf file format. SoC/ Eink controller hardware often requires converting the file into a vendor-specific file format. Caster/ Glider also uses a specific binary format. This project defines a common human-readable format (Interchangeable Waveform Format, IWF) and provides several tools for working with different binary formats and the IWF format.
|
||||||
|
|
||||||
#### Interchangeable Waveform Format
|
#### Interchangeable Waveform Format
|
||||||
|
|
||||||
|
@ -804,7 +820,7 @@ Each mode has its own mode section named [MODEx], where x is the mode ID, contai
|
||||||
- NAME: the name for that mode
|
- NAME: the name for that mode
|
||||||
- T*TABLE: the table used for the temperature in that mode
|
- T*TABLE: the table used for the temperature in that mode
|
||||||
|
|
||||||
There should be a number of LUTs, saved in the filename like PREFIX_TBx.csv, where x is the LUT ID. Each csv file should contain the a LUT like this: lut[src][dst][frame], which means, to transition from src greyscale level to dst greyscale level, at a certain frame in a frame sequence, what voltage should be applied to the screen (0/3: GND / Keep, 1: VNEG / To black, 2: VPOS / To white). Each line contains the frame sequence for one or more source to destination pairs.
|
There should be a number of LUTs, saved in the filename like PREFIX_TBx.csv, where x is the LUT ID. Each csv file should contain a LUT like this: lut[src][dst][frame], which means, to transition from src greyscale level to dst greyscale level, at a certain frame in a frame sequence, what voltage should be applied to the screen (0/3: GND / Keep, 1: VNEG / To black, 2: VPOS / To white). Each line contains the frame sequence for one or more source-to-destination pairs.
|
||||||
|
|
||||||
For example:
|
For example:
|
||||||
|
|
||||||
|
@ -823,13 +839,13 @@ The following converters are provided in the repo:
|
||||||
|
|
||||||
### Compatible Screens
|
### Compatible Screens
|
||||||
|
|
||||||
This project only focuses on driving off-the-shelf active matrix electrophoretics displays without integrated controllers. See [Screen Panels](#screen-panels) for differences between different types of screen panels available. That's being said, this project is compatible with majority of these panels, including sizes from 4.3" up to 13.3", and potentially supporting panels as large as 42" as well (additional power supply required in that case).
|
This project only focuses on driving off-the-shelf active matrix electrophoretic displays without integrated controllers. See [Screen Panels](#screen-panels) for differences between different types of screen panels available. That being said, this project is compatible with the majority of these panels, including sizes from 4.3" up to 13.3", and potentially supporting panels as large as 42" as well (additional power supply required in that case).
|
||||||
|
|
||||||
#### Screen Adapters
|
#### Screen Adapters
|
||||||
|
|
||||||
Different screen panels have different connectors. It would take a huge amount of space to have every possible screen connector on the motherboard. Instead, a series of different screen adapters are provided to adapt to screen with different pinouts.
|
Different screen panels have different connectors. It would take a huge amount of space to have every possible screen connector on the motherboard. Instead, a series of different screen adapters are provided to adapt to the screen with different pinouts.
|
||||||
|
|
||||||
The mainboard natives supports certain 40 pin screens, such as:
|
The mainboard natives support certain 40-pin screens, such as:
|
||||||
|
|
||||||
- 10.3" 1872x1404: ED103TC1, ES103TC2
|
- 10.3" 1872x1404: ED103TC1, ES103TC2
|
||||||
- 10.1" 2232x1680: GDEW101M01, GDEW101C01
|
- 10.1" 2232x1680: GDEW101M01, GDEW101C01
|
||||||
|
@ -838,7 +854,7 @@ To see which adapter might work for your screen, check out the [Appendix 1 - Scr
|
||||||
|
|
||||||
#### Pixel Rate Considerations
|
#### Pixel Rate Considerations
|
||||||
|
|
||||||
The input protocol and processing rate limits the screen model supported.
|
The input protocol and processing rate limit the screen model supported.
|
||||||
|
|
||||||
Limit from processing rate (logic and routing delay):
|
Limit from processing rate (logic and routing delay):
|
||||||
|
|
||||||
|
@ -886,7 +902,7 @@ Common screen resolution peak pixel rate (with CVT-RBv2):
|
||||||
|
|
||||||
( Calculate yourself: [Video Timings Calculator by Tom Verbeure](https://tomverbeure.github.io/video_timings_calculator) )
|
( Calculate yourself: [Video Timings Calculator by Tom Verbeure](https://tomverbeure.github.io/video_timings_calculator) )
|
||||||
|
|
||||||
Rendering the grayscale requires the screen to be refreshed at 85Hz (85Hz is the Eink supported refresh rate, 60Hz can be made to work with some effort in some cases). Running input refresh rate lower than the internal refresh rate incurs additional processing latency from both source (PC) and monitor due to buffering.
|
Rendering the grayscale requires the screen to be refreshed at 85Hz (85Hz is the supported refresh rate by Eink, 60Hz can be made to work with some effort in some cases). Running an input refresh rate lower than the internal refresh rate incurs additional processing latency from both source (PC) and monitor due to buffering.
|
||||||
|
|
||||||
### Case
|
### Case
|
||||||
|
|
||||||
|
@ -903,16 +919,16 @@ Here is a list of helpful references related to driving EPDs:
|
||||||
* An early tool for reading Eink's wbf file format: https://github.com/fread-ink/inkwave
|
* An early tool for reading Eink's wbf file format: https://github.com/fread-ink/inkwave
|
||||||
* A more up-to-date Eink's wbf format parser: https://patchwork.kernel.org/project/linux-arm-kernel/patch/20220413221916.50995-2-samuel@sholland.org/
|
* A more up-to-date Eink's wbf format parser: https://patchwork.kernel.org/project/linux-arm-kernel/patch/20220413221916.50995-2-samuel@sholland.org/
|
||||||
|
|
||||||
On the topic of color screen resolution, color mapping, subpixel rendering:
|
On the topic of color screen resolution, color mapping, and subpixel rendering:
|
||||||
|
|
||||||
* Klompenhouwer, Michiel A., and Erno H. A. Langendijk. “59.4: Comparing the Effective Resolution of Various RGB Subpixel Layouts.” SID International Symposium Digest of Technical Papers, vol. 39, no. 1, 2008, pp. 907–10, https://doi.org/10.1889/1.3069822.
|
* Klompenhouwer, Michiel A., and Erno H. A. Langendijk. “59.4: Comparing the Effective Resolution of Various RGB Subpixel Layouts.” SID International Symposium Digest of Technical Papers, vol. 39, no. 1, 2008, pp. 907–10, https://doi.org/10.1889/1.3069822.
|
||||||
* Lai, Chih-chang, and Ching-chih Tsai. “A Modified Stripe-RGBW TFT-LCD with Image-Processing Engine for Mobile Phone Displays.” IEEE Transactions on Consumer Electronics, vol. 53, no. 4, 2007, pp. 1628–33, https://doi.org/10.1109/TCE.2007.4429262.
|
* Lai, Chih-chang, and Ching-chih Tsai. “A Modified Stripe-RGBW TFT-LCD with Image-Processing Engine for Mobile Phone Displays.” IEEE Transactions on Consumer Electronics, vol. 53, no. 4, 2007, pp. 1628–33, https://doi.org/10.1109/TCE.2007.4429262.
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
This document, other than references explicitly given with their corresponding license, is released into public domain.
|
This document, other than references explicitly given with their corresponding license, is released into the public domain.
|
||||||
|
|
||||||
The hardware design is released under the CERN Open Source Hardware License strongly-reciprocal variant, CERN-OHL-S. A copy of the license is provided in the source repository. Additionally, user guide of the license is provided on ohwr.org.
|
The hardware design is released under the CERN Open Source Hardware License strongly-reciprocal variant, CERN-OHL-S. A copy of the license is provided in the source repository. Additionally, a user guide of the license is provided on ohwr.org.
|
||||||
|
|
||||||
The firmware code is licensed under the MIT license with the following exceptions:
|
The firmware code is licensed under the MIT license with the following exceptions:
|
||||||
|
|
||||||
|
@ -926,13 +942,13 @@ To be written
|
||||||
|
|
||||||
### Screen List
|
### Screen List
|
||||||
|
|
||||||
This is a list of Eink screens and their key parameters and their compatibilities with Caster/ Glider. The information are gathered from public sources, so they might be incorrect. This is not a complete list of all screens Eink have ever produced or in production. This table is intended for hobbiests buying used screens. If you are designing a product with Eink screen please contact Eink directly.
|
This is a list of Eink screens their key parameters and their compatibilities with Caster/ Glider. The information is gathered from public sources, so they might be incorrect. This is not a complete list of all screens Eink has ever produced or is in production. This table is intended for hobbyists buying used screens. If you are designing a product with Eink screen please contact Eink directly.
|
||||||
|
|
||||||
Other than a few exceptions, only screens without integrated TCON are listed here (in other words, SPI screens are generally not included here). These screens are the main focus of this project anyway.
|
Other than a few exceptions, only screens without integrated TCON are listed here (in other words, SPI screens are generally not included here). These screens are the main focus of this project anyway.
|
||||||
|
|
||||||
Screen size is the first 3 numbers in the model number, so it's not listed separately in the table. For example, ED060SC4 is 6.0", ED097OC1 is 9.7", and ES133UT1 is 13.3".
|
Screen size is the first 3 numbers in the model number, so it's not listed separately in the table. For example, ED060SC4 is 6.0", ED097OC1 is 9.7", and ES133UT1 is 13.3".
|
||||||
|
|
||||||
The adapter column refers to the adapter needed for this particular screen, however there is no guarantee that it would work, even if it's listed as tested.
|
The adapter column refers to the adapter needed for this particular screen, however, there is no guarantee that it would work, even if it's listed as tested.
|
||||||
|
|
||||||
| Model Name | Model Number | FPL Platform | Resolution | Marketing Name | R Typ | CR Typ | Year | Interface | Pin Count | Adapter | Tested? |
|
| Model Name | Model Number | FPL Platform | Resolution | Marketing Name | R Typ | CR Typ | Year | Interface | Pin Count | Adapter | Tested? |
|
||||||
| ---------- | ------------ | ------------ | ----------- | --------------------------- | ----- | ------ | ----- | --------- | --------- | ------- | ------- |
|
| ---------- | ------------ | ------------ | ----------- | --------------------------- | ----- | ------ | ----- | --------- | --------- | ------- | ------- |
|
||||||
|
@ -987,7 +1003,9 @@ The adapter column refers to the adapter needed for this particular screen, howe
|
||||||
| ED060KH4 | | 320 | 1448x1072 | Carta | | | | TTL | | | |
|
| ED060KH4 | | 320 | 1448x1072 | Carta | | | | TTL | | | |
|
||||||
| ED060KH6 | VB3300-FOE | 320 | 1448x1072 | Carta | | | | TTL | | | |
|
| ED060KH6 | VB3300-FOE | 320 | 1448x1072 | Carta | | | | TTL | | | |
|
||||||
| ED060KHC | | | 1448x1072 | | | | | TTL | | | |
|
| ED060KHC | | | 1448x1072 | | | | | TTL | | | |
|
||||||
|
| ED060KHE | VD1405-FOH | | 1448x1072 | Carta 1300 | | | | TTL | 34 | 34P-A | |
|
||||||
| EC060KH3 | SA1452-FOA | | 1448x1072 | Kaleido | | | | TTL | | | |
|
| EC060KH3 | SA1452-FOA | | 1448x1072 | Kaleido | | | | TTL | | | |
|
||||||
|
| EC060KH5 | SC1452-FOD | | 1448x1072 | Kaleido 3 | | | | TTL | 34 | 34P-A | |
|
||||||
| ED061KC1 | VD1405-FAA | 400 | 1648x824 | Carta 1200 | | | | TTL | | | |
|
| ED061KC1 | VD1405-FAA | 400 | 1648x824 | Carta 1200 | | | | TTL | | | |
|
||||||
| ED067KC1 | VB3300-FGA | 320 | 1800x900 | Carta | 45% | 16:1 | 2020 | TTL | 50 | 50P-B | |
|
| ED067KC1 | VB3300-FGA | 320 | 1800x900 | Carta | 45% | 16:1 | 2020 | TTL | 50 | 50P-B | |
|
||||||
| EC067KC1 | SA1452-FGA | | 1800x900 | Kaleido | | | | TTL | 50 | 50P-B | |
|
| EC067KC1 | SA1452-FGA | | 1800x900 | Kaleido | | | | TTL | 50 | 50P-B | |
|
||||||
|
|
Loading…
Reference in a new issue