Skip to content

CIS565-Fall-2018/Final-Project

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

27 Commits
 
 
 
 

Repository files navigation

Final Project

CIS 565: GPU Programming and Architecture

University of Pennsylvania

Fall 2018

The final project gives you an opportunity to embark on a large GPU programming endeavor of your choice. You are free to select an area in graphics, GPU computing, or both.

You can

  • fulfill a real need in the community,
  • explore a new API,
  • reproduce the results of recent research,
  • add a novel extension to existing work, or
  • implement something completely original.

Expect this to be 2-3x more work than the hardest project this semester. The best projects will require a time commitment of at least 100 hours per student. It will be worth it.

Guidelines

  • Form teams of two or three students. Each team member will receive the same grade. Teams of four will be considered, but will be expected to build something truly amazing like this.
    • Teams of one are discouraged and will only be considered on a case-by-case basis.
  • Use GitHub. We encourage, but do not require, you to develop in a public repo as open source.
  • Programming language, graphics and compute APIs, and target platforms are up to you.
  • You are allowed to use existing code and libraries. These should be prominently credited and your code should be easily identifiable. Be incredibly clear about what is your work and what is not.

Project Ideas

DirectX Raytracing

  • Real-time rendering pipeline + add ons

Resources:

WebGPU - Next-generation 3D Graphics on the Web

Background

Ideas

  • glTF 2.0 PBR renderer for NXT
  • Vulkan backend for NXT
  • CUDA rasterizer backend for NXT
  • Tensorflow operators using NXT compute shaders
  • Anything to help with NXT design

WebAssembly

http://webassembly.org/

  • Prototype a graphics engine in C++/OpenGL ES and "compile" it for the web using WebAssembly. Provide benchmarks.
  • Answer the question: how can an existing JavaScript codebase use WebAssembly? Rewrite the whole thing in C++? Rewrite hot fine-grained modules, e.g., matrix and vector types? Rewrite hot coarse-grained modules, e.g., the physics engine?

Also talk to Austin Eng, who used WebAssembly for his Senior Design, and now is a part of the Chrome team. Austin will also be a guest speaker on 11/26.

glTF

https://www.khronos.org/gltf

Disclosure: Patrick is the chair of the Khronos 3D Formats Working Group. 😏

Unity importer/exporter

https://github.com/KhronosGroup/UnityGLTF

Collaborate with Microsoft and Mozilla on the Unity glTF importer and exporter

Autodesk Maya or Max importer or exporter

Develop an open-source Maya or Max plugin for glTF import or export

WebGL

WebGL 2

Extend

WebGL vs. OpenGL ES Mobile Power Usage

On mobile, how does the power usage of JavaScript/WebGL compare to C++/OpenGL ES 2 (or Java/ES or Objective C/ES)? For example, if the same app is developed in WebGL and OpenGL ES, which one drains the battery first - and why? What type of benchmarks need to be developed, e.g., CPU bound, GPU compute bound, GPU memory bound, etc.?

WebGL for Graphics Education

Create a tutorial using WebGL that teaches either basic GPU architecture (parallelism, branches, multithreading, SIMD, etc.) or Tile-Based Architectures like those used in mobile GPUs. For inspiration, see Making WebGL Dance by Steven Wittens.

gpu.js

https://github.com/gpujs/gpu.js

Build something with gpu.js:

gpu.js is a JavaScript Acceleration library for GPGPU (General purpose computing on GPUs) in Javascript. gpu.js will automatically compile simple JavaScript functions into shader language and run them on the GPU.

Cesium

https://cesiumjs.org/

3D Mapping WebGL Engine

Disclosure: I started this project. 😏

Integration with three.js and other engines

Expand on https://cesium.com/blog/2017/10/23/integrating-cesium-with-threejs/ to fully explore integrating Cesium with other WebGL engines such as three.js and BabylonJS - both by overlaying two canvases and by combining the rendering loop.

Ocean rendering

Improve the quality of the global-scale ocean/water rendering in Cesium. Add any required WebGL 2 features to Cesium

Resources

Snow rendering

Expand on the particle system and new terrain materials to add snow rendering to Cesium.

BabylonJS

https://www.babylonjs.com/

Open Issues

  • More postprocesses:
  • Better bloom
  • Cartoon
  • Paper
  • You name it :)

Vulkan

renderdoc

Contribute to renderdoc.

In Defense of Batching

Does batching still help with Vulkan? If so, when it is worth it?

Domain-specific shading languages

Create a domain-specific shading language targeting SPIR-V. Perhaps a language tuned for CSG, voxels, or ray marching.

Utility library

Implement a new abstraction layer using Vulkan that is higher level than Vulkan, but lower level than, for example, Unity.

Multithreaded Engine

Prototype a small engine with multithreading for LOD and culling.

Tutorial Series

Write a Vulkan for OpenGL developers tutorial series.

VR

  1. Performance analysis of porting an engine to VR
    • Naive stereo rendering vs. multi-view
  2. Implement barrel distortion and chromatic aberration filters with optimizations
    • In practice, use filters from VR vendors to avoid making users sick
  3. More precise object culling with a volume derived from the hidden area mesh
    • Is this practical and useful?
  4. In each eye, most of the same fragments will pass the depth test, can this coherence be used to optimize?
    • Evaluate the checkerboard stencil in radial density masking as a general optimization
  5. Does it have better visual quality than rendering a scene at half-resolution and upsampling with only a nominal cost?
    • Expand radial density masking / fixed foveated rendering to apply geometric/material LOD to objects in the periphery
  6. Implement a simulation for avoiding judder
  7. Compare async timewarp, spacewarp, and late orientation warping, and heuristics for selecting between them
  8. Improve spacewarp with a sparse voxel octree
    • Not sure if this will work, but perhaps could improve occlusion artifacts at a reasonable performance and memory cost

CUDA / GPU Computing

3D Machine Learning

3D Machine Learning = Computer Vision + Graphics + Machine Learning

Autonomous Cars and Simulation

GPU accelerate parts of autonomous cars.

Embedded Systems

Use Jetson kits for interesting applications in computer vision, autonomous vehicles, drones, robotics etc.

See success stories.

Ps. You may need to procure hardware, but we can help with references.

Other

Google Tango

Anything that runs in real-time using the GPU and the Tango API.

Anti-Ideas

Please do not propose yet-another-CUDA-fluid/smoke/cloth simulation unless it has a unique spin such as using

  • Vulkan compute shader
  • NXT compute shader
  • Multi-GPU
  • A very sophisticated simulation

Likewise, please do not propose extend-my-CUDA-path-tracer-with-these-n-effects unless it is truly unique.

Previous Semesters

For inspiration, browse the CIS 565 final projects from previous semesters:

A guideline is that your project should be better than last semester's projects; that is how we move the field forward.

Selected Projects

Conferences and Journals

Browse these for ideas galore!

Timeline

Monday 11/12 - Project Pitch

Sign up for a time slot ASAP.

Your project pitch is a 15-minute meeting with Patrick, Shehzan, and the TAs, and a write-up no longer than one page that includes an overview of your approach with specific goals and weekly milestones for 11/19, 11/26, 12/03, and 12/10. First, focus on why there is a need for your project. Then describe what exactly you are going to do. In addition to your write-up, provide supplemental figures, images, or videos.

Think of your pitch as if you are trying to get a startup funded, convincing your company to start a new project, or responding to a grant. For an example, see Forward+ Renderer using OpenGL/Compute Shaders by Bradley Crusco and Megan Moore (this example pitch does not include weekly milestones, which is new this semester).

Before the meeting:

  • Email your one page pitch and any supplemental material to Patrick, Shehzan, and the TAs by end of Sunday 11/11. Sooner is better. To really hit a home run, consider prototyping something before the meeting.
    • Use the subject as [CIS 565 2018 Final Project] Name1, Name2, Name3. Include a project/team name, if chosen.

You are free to start working on your project before the pitch. As long as you have followed the guidelines, it is more than likely that your project will be approved. We may ask you to tweak it, move the milestones etc.

After the meeting:

  • Push your pitch to a new GitHub repo for your project
  • Add the names of the team members, a project name (if any) and the link to the Github repository (if open source) to the Google Group Final Projects Post.

Monday 11/19 - Milestone 1

Your first presentation should be 4 minutes. Present your work-in-progress. Your presentation should include a few slides, plus videos, screenshots, or demos if possible. Be sure to

  • Demonstrate working code (videos and screenshots are OK; it doesn’t have to be live).
  • Provide a roadmap with future weekly milestones up to and including the final presentation on Friday, December 7.

See the Cesium Presenter's Guide for tips on presenting. Be sure to present as a team; for a great example, see http://www.youtube.com/watch?v=OTCuYzAw31Y

After class, push your presentation to your GitHub repo.

Monday 11/26 & Wednesday 11/28 - Milestone 2

A 5 minute presentation on your progress over the past week. Demonstrate how you reached or exceeded the goals for this milestone. If you didn't reach them, explain why. Remind us of your upcoming milestones, and adjust them if needed.

After class, push your presentation to your GitHub repo.

Note: Because we have guest speakers on both 11/26 and 11/28, we will be splitting the the presentations into 2 groups, half on 11/26 and half on 11/28.

Monday 12/03 - Milestone 3

Same format as Milestone 2.

Friday 12/7 Friday 12/10 - Final Presentation + Project Due

4-minute final presentation.

This should be a polished presentation with a 1-2 slide overview of the technical approach at a high-level of abstraction, followed by a demo/video of the results in different representative scenarios, followed by a careful performance analysis, and finally shortcomings of the approach.

It is OK to present this as a few slides with a demo/video for the results section, or to prepare a video for the entire presentation and then talk to the video as your presentation.

Please practice for timing; do not exceed five minutes.

By 5pm:

  • Push the following to GitHub
    • Final presentation slides/video
    • Final code - should be clean, documented, and tested
  • A detailed README.md including:
    • Name of your project
    • Your names and links to your website/LinkedIn/twitter/whatever
    • Choice screenshots including debug views
    • Link to demo if possible. WebGL demos should include your names and a link back to your github repo
    • Overview of technique and links to references
    • Link to video
    • Detailed performance analysis
    • Install and build instructions

As always, see How to make an attractive GitHub repo for tips on your README.md.

Grading

The final project is worth 50% of your final grade. The breakdown is:

  • Milestone 1: 25%
  • Milestone 2: 25%
  • Milestone 3: 25%
  • Final Presentation and code: 25%

Social Media

Feel free to share your successes, bloopers etc on social media. Patrick and I will retweet/share them. It'll be great to get the buzz going about your project. You may even get industry experts to chime in.

FAQ

I want to do a project on a topic that has been done in the past. Is that allowed?

The main goal of final projects is to move the course forward and current with the industry. If you are trying to do something similar to year(s) old project, then you are starting behind.

These kind of projects, such as building on top of Pathtracer or doing new procedural generation, will be allowed if the additions are going to be novel and haven't been previously done. So the bar is set high.

Whereas, for projects like Vulkan, VR, DirectX Raytracing, the technology is recent and not much work has been done. So you will be the pioneers of these, so the barrier to entry is lower. Working on these will also open the possibility of the project becoming a regular project in the future.

Simulations, physically based animations will be allowed if you are implementing a novel technique that is vastly different from the seminal work in that field.

I really want to work on a topic/technology, but I have limited or no experience.

Be brave. There are a ton of online courses out there. Additionally, we'll try to connect you to any industry experts we know of.

What if I'm not doing a graphics or visual project? What should I do for final demos?

It is completely ok to no do a graphics project. Not all useful software on GPU is grpahics related.

You can do a lot of things for final projects, including, but not limited to, some great graphs, comparisions with industry software etc.

I'm from CIS (or non-graphics). Can you suggest projects for me to work on?

The core piece of advice would be to take something really amazing you have done, and then port it to the GPU.

There are a ton of other topics you can think of as well. Machine Learning, deep learning, autonomous driving to name a few. Additionally, embedded systems with GPU such as Tegra or ARM GPUs, Apple Metal etc are also welcome.

It is all about doing projects using the GPU that are relevant to the industry and your field of interest.

I want to work on a project that requires data. I don't have any.

For projects like machine learning etc, a source data is always required. There are usually a lot of open datasets available, most of which are a simple google search away.

Also try talking to other departments, professors or students who might have such data. There is always a good chance by approaching the right people.

If you still cannot find it, we can help connect you to some industry experts who might have such data.

I've been working on a long term project (research/PhD/etc). Can I do my final project on that?

Yes, as long as:

  • There is no double-dipping (getting grades in 2 different courses for the same work).
  • The goals are clearly layed out.
  • The final project work is a GPU enhancement to other work.
  • Other conditions that may be taken up case-by-case.

I have to miss one of the milestones because .....

Missing milestones is NOT acceptable, except if you have matters such as interviews, recruitment etc, or obtain prior permission. In that case, do the following:

  • Ensure your team presents on the day of the milestone presentations.
  • Schedule a time with a TA (preferably Ottavio) and your team prior to the milestone presentations and discuss the progress made.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published