Skip to content

zjjjjjjj2017/compute_rasterizer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

About

This repository contains the source code for our papers about real-time software rasterization of point clouds, which can be 10 to 100 times faster than GL_POINTS. This is possible because GL_POINTS is built upon the triangle-oriented rendering pipeline that is not optimal for pixel-sized points.

The basic idea is to spawn a compute shader that transforms points to screen space, encodes depth and color into a single 64 bit integer, and uses atomicMin to compute the closest point for each pixel. The color value is then extracted from the interleaved depth+color buffer and converted into a regular OpenGL texture for display.

The latest improvement also groups about 10k points into batches, and each compute workgroup(128 threads) renders a batch(10k points), i.e., each thread renders about 80 points. This allows several batch-level optimizations such as frustum culling, LOD rendering, and adaptive precision. Adaptive precision picks a sufficient coordinate precision (typically just 10 bit per axis) depending on the projected batch size, which boosts brute-force performance due to lower memory bandwidth requirements.

The main branch is a slightly more user friendly version that allows loading LAS files via drag&drop. Other branches contain snapshots of the code made after evaluations for specific paper submissions:

Features and Limitations

  • Renders up to one billion points in about 8 milliseconds (hence 2 billion points in real-time, 60fps) on an RTX 3090.
  • You need to make sure not to load more than your GPU memory can handle. You'll need about 160MB for every 100 million points, plus 1GB or 2GB overhead.
  • Drag & Drop a LAS file into the window to load it. (no LAZ, yet)
  • Requires Windows and NVIDIA GPUs. Pull requests for AMD support are welcome.
  • Transforms each point cloud to the origin separately, and therefore won't work with multiple scans/tiles that are supposed to be in the same coordinate reference system.

Building

  • Clone the repository
  • Compile build/ComputeRasterizer.sln with Visual Studio 2022.
  • Run (ctrl + f5)
Method Location
basic ./modules/compute_loop_las
prefetch ./modules/compute_loop_las2 fastest, each thread fetches 4 points at a time
hqs ./modules/compute_loop_las_hqs High-Quality Shading
LOD ./modules/compute_loop_nodes Support for the Potree LOD format
LOD hqs ./modules/compute_loop_nodes_hqs

Citing

@article{SCHUETZ-2022-PCC,
	title =      "Software Rasterization of 2 Billion Points in Real Time",
	author =     "Markus Sch\"{u}tz and Bernhard Kerbl and Michael Wimmer",
	publisher = {arXiv},
	year =       "2022",
	month =      apr,
	URL =        "https://www.cg.tuwien.ac.at/research/publications/2022/SCHUETZ-2022-PCC/",
	doi = {10.48550/ARXIV.2204.01287},
	copyright = {Creative Commons Attribution 4.0 International}
}

About

Rendering Point Clouds with Compute Shaders

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • C++ 62.4%
  • C 32.4%
  • C# 4.2%
  • Objective-C++ 0.4%
  • JavaScript 0.3%
  • Objective-C 0.2%
  • Other 0.1%