Content deleted Content added
Artoria2e5 (talk | contribs) →Algorithm: ~ |
Mjones2160 (talk | contribs) Added citations and DSC 1.2b info |
||
(11 intermediate revisions by 9 users not shown) | |||
Line 14:
}}
'''Display Stream Compression''' ('''DSC''') is a [[Video Electronics Standards Association|VESA]]-developed [[video compression]] algorithm designed to enable increased display resolutions and frame rates over existing physical interfaces, and make devices smaller and lighter, with longer battery life.<ref name=DSC>{{cite press release |url=https://www.vesa.org/news/vesa-finalizes-requirements-for-display-stream-compression-standard/ |title=VESA Finalizes Requirements for Display Stream Compression Standard |publisher=VESA |date=24 January 2013 |access-date=20 March 2018 |archive-url=https://web.archive.org/web/20180321130439/https://www.vesa.org/news/vesa-finalizes-requirements-for-display-stream-compression-standard/ |archive-date=21 March 2018 |url-status=dead }}</ref> It is a low-latency algorithm based on [[delta modulation|delta PCM]] coding and [[YCoCg|YC{{sub|G}}C{{sub|O}}-R]] color space.<ref name=DSC /><ref name=vesa-etp200>{{cite web |url=http://www.vesa.org/wp-content/uploads/2014/04/VESA_DSC-ETP200.pdf |title=VESA Display Stream Compression |last1=Walls |first1=Frederick |last2=MacInni |first2=Sandy|date=3 March 2014 |publisher=VESA}}</ref>
== Effect ==
Although DSC is not mathematically [[
== Algorithm ==
Line 24:
** If RGB encoding is used, it is first converted to reversible [[YCgCo|YC{{sub|G}}C{{sub|O}}]].
** If "simple 4:2:2" is used, it is converted to 4:4:4 by adding missing chroma samples through interpolating neighboring pixels.
* Each component (1 luma,
* Bit rate control algorithm tracks color flatness and buffer fullness to adjust the quantization bit depth for a pixel group in a way that minimizes compression artifacts while staying within the bitrate limits.
** DSC can work in constant or variable bitrate mode. The minimum allowed bits-per-pixel (BPP) is 6 bit/px;<ref name="dsc12a"/>{{rp|52}} the typical BPP given on VESA's website is 8 bit/px.<ref name="VESA Codecs"/> The variable-bitrate is actually a way to temporarily disable the display link;<ref name="dsc12a"/>{{rp|125}} it only adds the
* Repeating recent pixels can be stored in 32-entry Indexed Color History (ICH) buffer, which can be referenced directly by each group in a slice; this improves compression quality of computer-generated images. Alternatively, prediction residuals are computed and encoded with [[entropy coding]] algorithm based on delta size unit-variable length coding (DSU-VLC).
* Encoded pixel groups are then combined into slices of various height and width; common combinations include 100% or 25% picture width, and 8-, 32-, or 108-line height.
Line 36:
DSC version 1.0 was released on 10 March 2014, but was soon deprecated by DSC version 1.1 released on 1 August 2014. The DSC standard supports up to a {{ratio|3:1}} compression ratio (reducing the data stream to 8 bits per pixel) with constant or variable bit rate, RGB or [[YCbCr|{{YCbCr}}]] [[chroma subsampling|4:4:4]], 4:2:2, or 4:2:0 color format, and color depth of 6, 8, 10, or 12 bits per color component.
DSC version 1.2 was released on 27 January 2016 and is included in version 1.4 of the DisplayPort standard; DSC '''version 1.2a''' was released on 18 January 2017.<ref>https://app.box.com/s/vcocw3z73ta09txiskj7cnk6289j356b/file/203635076004</ref> The update includes native encoding of 4:2:2 and 4:2:0 formats in six-pixel containers, 14/16 bits per color, and minor modifications to the encoding algorithm. The specification for DSC '''version 1.2b''' was published on 12 August 2021,<ref>https://app.box.com/s/vcocw3z73ta09txiskj7cnk6289j356b/file/847125003356</ref> with [[VESA]]'s website claiming that DisplayPort 1.4a was the first iteration to take advantage of the new version.<ref>https://vesa.org/vesa-display-compression-codecs/dsc/</ref> However, conflicting information on the DisplayPort website claims 1.2a is still the newest version.<ref>https://www.displayport.org/faq/#tab-display-stream-compression-dsc</ref>
On 4 January 2017, [[HDMI 2.1]] was announced which supports up to [[10K resolution]] and uses DSC 1.2 for video that is higher than 8K resolution with 4:2:0 [[chroma subsampling]].<ref name=HDMI21PressRelease>{{cite news |url=http://www.hdmi.org/press/press_release.aspx?prid=145 |title=HDMI Forum announces version 2.1 of the HDMI specification |publisher=HDMI.org |date=2017-01-04 |access-date=2017-01-10 |archive-date=2017-01-08 |archive-url=https://web.archive.org/web/20170108081018/http://www.hdmi.org/press/press_release.aspx?prid=145 |url-status=dead }}</ref><ref name=HDMI21Introduction>{{cite news |url=http://www.hdmi.org/manufacturer/hdmi_2_1/index.aspx |title=Introducing HDMI 2.1 |publisher=HDMI.org |access-date=2017-01-10 |archive-date=6 January 2017 |archive-url=https://web.archive.org/web/20170106195344/http://www.hdmi.org/manufacturer/hdmi_2_1/index.aspx |url-status=dead }}</ref><ref name=HDMI21January2017Anandtech>{{cite news |url=http://www.anandtech.com/show/11003/hdmi-21-announced-8kp60-48gbps-cable |archive-url=https://web.archive.org/web/20170106100230/http://www.anandtech.com/show/11003/hdmi-21-announced-8kp60-48gbps-cable |url-status=dead |archive-date=January 6, 2017 |title=HDMI 2.1 Announced|author=Anton Shilov |publisher=Anandtech |date=2017-01-05 |access-date=2017-01-10}}</ref>
Using DSC with HBR3 transmission rates, DisplayPort{{nbsp}}1.4 can support 8K UHD ({{resx|7680|4320}}) at 60{{nbsp}}Hz or 4K UHD ({{resx|3840|2160}}) at
DisplayPort version 1.4a was published in April 2018.<ref name="DP 1.4a FAQ">{{cite web |title=FAQ{{Snd}} DisplayPort |url=https://www.displayport.org/faq/ |archive-url=https://web.archive.org/web/20181224123542/https://www.displayport.org/faq/ |archive-date=24 December 2018}}</ref> VESA made no official press release for this version. It updated DisplayPort's DSC implementation from DSC 1.2 to 1.2a.<ref name="DSC Display Stream Compression">{{cite web |title=DSC Display Stream Compression |url=https://vesa.org/vesa-display-compression-codecs/dsc/ |archive-url=https://web.archive.org/web/20190710163312/https://vesa.org/vesa-display-compression-codecs/dsc/|archive-date=10 July 2019}}</ref>
HDMI 2.1, which can also use DSC 1.2, is also capable of 8K up to 120 Hz with HDR.
== References ==
|