- April 30th, Vulkan Developer Day in Montreal, hosted by Ubisoft
data:image/s3,"s3://crabby-images/c291b/c291b81043c4382267e693f99a7524b164233b45" alt=""
- UVs map into a gradient texture
- to change the colors the UVs are adjusted to point to other sections in gradient texture
data:image/s3,"s3://crabby-images/6f16f/6f16fbfd8a743f17dd2ba4e40025a8d4a4e1a1e3" alt=""
- overview of the shader authoring format
- shader input parameters are defined without thinking about how they are bound
- passing data between shader stages is abstracted
- giving the system flexibility to pack as required
data:image/s3,"s3://crabby-images/13ac1/13ac166cb912d07ca0237ef7db08fc5f3a552976" alt=""
- microarchitectural details of the NVIDIA Volta architecture
- registers are divided into two 64 bit banks
- reduction of bank conflicts with register remapping can improve performance by 15%
- shorter latency for shared memory atomics
data:image/s3,"s3://crabby-images/0b5a0/0b5a0510b44710d1eb2964e2ac083d3465ad647e" alt=""
- MatCap texture contains lighting information for all camera space normals
- needs to be recalculated when camera direction changes
data:image/s3,"s3://crabby-images/1ff43/1ff43b023ee77f8a03ab4ac85ed64c7886c39856" alt=""
- uses a texture based and camera facing quad approach instead of a post-processing bloom
- lighting for terrain rendered into a low-res light map, sampled per-fragment
- terrain is rendered at 720p, up-scaled to 1080p
data:image/s3,"s3://crabby-images/b1851/b18512f5f2fd32558f6fd745979cbfdbdd4093f5" alt=""
- algorithm to sum regions from arrays or grids in constant time
- need larger storage format, increase depends on largest range that needs to be summed
- compatible with bilinear filtering for sub-pixel values
data:image/s3,"s3://crabby-images/937ec/937ecf29ebbfd3d1d3f0438116b81e014e4cb5ca" alt=""
- unity graphics team is looking to gather feedback to improve the roadmap
- current approach recursively processes a single ray until it terminates
- new approach calculates each step for all rays in seperate passes
- memory read seems to be limiting factor, shows a few optimizations for that
data:image/s3,"s3://crabby-images/d1fd8/d1fd8b5e2d0fc527a2f211d2e2994854d029a09b" alt=""
- available with AMD vega architecture
- pack two FP16 into FP32 register
- reduce ALU instructions count, reduce VGPR usage
- how to detect FP16 code generation in FXC disassembly and GCN ISA output
- discussion of pitfalls and common use-cases
- how to deal with FP16 constants
data:image/s3,"s3://crabby-images/69288/69288244d08ab918bf4489db40ef68ed0d81fb4c" alt=""
- combination of ripples and streaking effect
- blending between the two effects based on surface orientation
- this post covers the implementation of the streaking effect
data:image/s3,"s3://crabby-images/f754c/f754c465fe0512753084325a3d65c2efa66cb426" alt=""
- many BC7 encoders compress all channels equally
- for color textures, errors in red and blue are less noticeable
- YCbCr color space allows better compression by reducing the number of bits used for chroma
data:image/s3,"s3://crabby-images/bf067/bf06756e5e29fe077d025ecc8842850da5748c4b" alt=""
- discusses issue with the ispc implementation
- compression has quality problems with grayscale textures
data:image/s3,"s3://crabby-images/00be0/00be0d056196ba3ed934f88cd0214da423ed248d" alt=""
- survey of methods utilizing Monte Carlo for light transport in participating media
data:image/s3,"s3://crabby-images/22295/222957bb5b9a4dc6af33be0e18cedbb2464097a4" alt=""
- list of resources for beginners aimed at shader toy like graphics programming
- A C++14/C++17 header-only library for simple, efficient, and robust serialization/deserialization of glTF 2.0