I am running a small survey to be able to improve the series further this year.
If you have two minutes to spare, please fill out the survey https://goo.gl/forms/nNPzrRpiMERIgtBl2
This week also contains articles that have been published during my vacation since issue 67
- start of series for programmers with D3D11 experience starting to learn D3D12
- explains what command queues are, how they express different GPU execution timelines and how fences allow synchronization between CPU and GPU
data:image/s3,"s3://crabby-images/0745f/0745f97a6eb5e4ba433a2f49b96883a7b6fd660a" alt=""
- explains how to render water using WebGL, Rust, and WebAssembly
- water supports reflection and refraction
- reflections are rendered using a reflection plane technique, that mirrors the world and clips fragments if they are below the water plane
data:image/s3,"s3://crabby-images/1da6e/1da6e228048e91d308a7055bdd4ee8e3db9431c7" alt=""
- shows how to use screen space derivatives to create hard edges on a mesh in the pixel shader
- how to calculate greyscale from colors
data:image/s3,"s3://crabby-images/fd7b8/fd7b89503f98ed608fa78ccbc733c47953204d03" alt=""
- video explaining the rendering equation in an easy to understand and visual way
data:image/s3,"s3://crabby-images/6d578/6d57872fd93e693eb1b08332deeb5a66206a337a" alt=""
- list of common patterns for shadertoy programming
- included are: normalizing screen coordinates, color management (hue, sRGB), line drawing, antialiasing, blending, vector math, and random value generation
data:image/s3,"s3://crabby-images/ef259/ef259d8b165356e61d8e0489b0b4b9b3cedec4a0" alt=""
- preprint of the article to appear in GPU Zen 2 talking about the implementation details (C++ and GLSL)
- replaces the 3D histogram transformation with three 1D histogram transformations
- improves quality of the result under mipmapping and shows how to generate correct results with compressed texture formats
data:image/s3,"s3://crabby-images/820ff/820ffce337dd6874528167fa541d702d21fc5e77" alt=""
- walkthrough of steps to learn graphics programming
- recommends starting that beginners start with a raytracer/rasterizer from scratch before starting to use any graphics API
- list of project ideas for beginners
data:image/s3,"s3://crabby-images/63a06/63a06a02b01bc64ce579c473596d3e85a14101da" alt=""
- explains how to rasterize the glyphs from a font into a texture. Providing the coverage information that is required by the technique discussed in part 1 and 2
- includes code for the OpenGL compute shader
- overview of typography terms and explain how to correctly position the glyphs to form the final text on the screen
data:image/s3,"s3://crabby-images/b0280/b0280e852a825b935f3f69c1682fde3e6455a5d4" alt=""
- presents what vertex attributes are and how they are interpolated to deal with perspective distortions correctly
- uses this knowledge to interpolate normals and UV coordinates for the sponza model
data:image/s3,"s3://crabby-images/debcb/debcb323216358248cfa9740e658c752ef7a0614" alt=""
Part 1 of the article:
- explains how classical forward/deferred pipelines work and how tiled and clustered algorithms can be used to extend these ideas
- includes animations to show the concepts in a more visual way
- presents strengths and weaknesses for each technique
Part 2 of the article:
- presents the clustered forward shading implementation
- how to subdivide the camera frustum into clusters and implement light culling
- provides links to further information sources
data:image/s3,"s3://crabby-images/6d410/6d4104c51bcbd1a493bb16c929ff7460369750c2" alt=""
- frame breakdown of the Rise of the Tomb Raider with D3D12 on PC
- uses a light pre-pass architecture
- lens flares don’t use a visibility query but instead use the depth buffer to calculate visibility
- talks about shadow mapping, ambient occlusion, depth-aware upscaling, reflections, hair rendering, volumetrics, and tone mapping
data:image/s3,"s3://crabby-images/daa48/daa484bbe745249346c4b478c1998b73dc3c4378" alt=""
- explains how to apply an expanding color effect that converts the world from greyscale back to color as post-processing effect using Unity scriptable render pipeline
- presents how to reconstruct world space position from the depth buffer
data:image/s3,"s3://crabby-images/ff239/ff23900757a7d24876b577bbf605c0e7cabf9288" alt=""
- shows how to set up a Docker container image that is able to run shader compilers
- supported are: DXC, FXC, GLSLang, AMD Radeon Graphics Analyzer, DXIL signing, SMOL/V and Vulkan SDK
data:image/s3,"s3://crabby-images/e7aa6/e7aa6143c77f11e46fecf8fb6ed4729b8c5c6f9f" alt=""
If you are enjoying the series and getting value from it, please consider supporting this blog.
Support this blog