SlideShare a Scribd company logo
1 of 65
Solving Visibility and
Streaming in The Witcher 3:
Wild Hunt with Umbra 3
Jasin Bushnaief, Umbra Software
Przemysław Czatrowski, CD Projekt RED
Agenda
INTRODUCTION
UMBRA 3 OVERVIEW
THE WITCHER 3 REQUIREMENTS
MIDDLEWARE AND THE REDEngine 3
UMBRA 3 IN REDEngine 3
3
UMBRA
SOFTWARE
OCCLUSION CULLING MIDDLEWARE FOR 3D
GAMES
FOUNDED IN 2007
14 EMPLOYEES
BASED IN HELSINKI, FINLAND
SUPPORT OFFICE IN SEATTLE, WA
“Level artists are there to fill the
world with content. Integrating Umbra saved
us not only artist time but the time to create
and maintain an efficient visibility culling
solution. Umbra’s support provides us with the
solutions and features that we need.”
“Umbra’s technology is playing an important role
in the creation of our next universe, by freeing our artists
from the burden of manual markups typically associated
with polygon soup.”
Video games
powered by Umbra 3
Occlusion Culling
SO WHAT’S
ANYWAY?
UMBRA 3 OVERVIEW
POLYGON
SOUP
OCCLUSION
DATA
VISIBLE
OBJECTS
WHY LICENSE?
+ SAVE ENGINEERS’ TIME
+ SAVE ARTISTS’ TIME
+ IT’S EASY
+ PORTABLE
+ PROVEN
+ SUPPORT
- ENGINEERS
DON’T GET TO
ROLL THEIR
OWN 
The Witcher 3 Requirements
HOW TO SATISFY
IN UMBRA 3?
THE WITCHER 3
REQUIREMENTS
• LARGE, OPEN WORLD
→PVS, MANUAL STUFF OUT OF QUESTION
• UMBRA IS AUTOMATIC
• STREAMING
• LODs
POLYGON
SOUP
OCCLUSION
DATA
STREAMING IN UMBRA 3
STREAMING IN UMBRA 3
STREAMING IN UMBRA 3
STREAMING IN UMBRA 3
VISIBLE
OBJECTS
COMBINED
DATA
STREAMING CHALLENGES
• INDEPENDENT BLOCKS
• MATCH ON BORDERS
• DO IT QUICKLY!
LODs IN UMBRA 3
• PREVIOUSLY: SCENE CONSISTS OF
SINGLE OBJECT INSTANCES
• PROBLEMS:
– NEED MULTIPLE LOD LEVELS
– SELF-OCCLUSION BETWEEN LEVELS
– LOD HIERARCHIES?
LODs SOLVED
DISTANCE RANGE
LOD 0
LOD 1
LOD 2
LOD 3
Z = 0 Z = LIKE, A LOT
(OCCLUDER)
LOD CHALLENGES
• DISTANCE REFERENCE POINT
• OTHER CRITERIA FOR LOD
SELECTION
• SMARTER LOD OCCLUDERS
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
ABOUT CD PROJEKT RED
• Located in Warsaw and Cracow, Poland
• Established in 2002
• Focused on RPGs
ABOUT CD PROJEKT RED
• The Witcher (2007)
• PC, heavily modified Aurora Engine
• The Witcher 2: Assasins of Kings (2011)
• PC, heavily modified Aurora Engine
• The Witcher 2: Assasins of Kings Enhanced Edition (2012)
• PC/X360, REDengine 2
• metacritics score: 88
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
ABOUT CD PROJEKT RED
• The Witcher 3: Wild Hunt
• REDengine 3
• Releasing in February 2015
• PC/XBOX / PS4
• Cyberpunk 2077
• REDengine 3
• Release date TBD
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
THE WITCHER 3: WILD HUNT
35x bigger than The Witcher 2
• open world
• complex streaming
• a lot of tools refactoring
• different approaches
Engine team:
• 16 people
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
AGENDA
• Why middleware?
• Things we consider
• Umbra 3 as middleware for REDengine 3
• Integration process
• Editor features
• Cooker / data generation
• Game features
• Summary
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
WHY MIDDLEWARE?
• Pros
• Too much time to provide own solutions
• Documentation
• Customer support
• Often access to source code
• Specific solutions for specific game
• Cons
• Evaluation time
• Pipeline modifications
• Code integrations
• Code not written by us
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
WHY MIDDLEWARE?
• “Business” aspects
• Documentation – quality
• Customer support
• Changes to our pipeline
• Source / libs
• Technical aspects
• Changes to our pipeline
• Memory management
• Multithreading
• Amount of data to provide
• How it “fits” the engine
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
WHY MIDDLEWARE?
• Middlewares that we use in the game
• Umbra 3
• PhysX
• APEX
• SpeedTree
• Wwise
• Scaleform
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
UMBRA 3 AS A MIDDLEWARE
FOR REDengine 3
• Documentation
• Escription of the classes, methods and
concepts behind solutions
• basic tutorials
• Access to source code /
libraries
• Both
• Customer support
• Great
• Really short response time
• Precise answers and solution suggestions
• Changes in our pipeline
• From the artists’ point of view - none
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
UMBRA 3 AS A MIDDLEWARE
FOR REDengine 3
• Memory management
• Ability to plug in your own allocator
• Multithreading
• Multithreaded building and querues
• Amount of data to provide
• Triangle soup
• No additional data created by artists
• Additional work
• Coming up with ID scheme
• Including occlusion culling in the
renderingpart
• Tools for building occlusion data
SOLVING VISIBILITY in REDengine 3 with UMBRA 3
Editor features
UMBRA 3 IN REDengine 3
UMBRA 3 IN REDengine 3
OCCLUSION DATA STREAMING
UMBRA 3 IN REDengine 3
OCCLUSION DATA STREAMING
1. From certain camera position required set of Tiles
is determined
2. If the newly determined set differs from the
currently used one, asynchronous computation starts
3. Precooked buffers are streamed in (only for Tiles,
that had no data streamed in yet)
4. Tome objects are created (only for Tiles that
haven’t had this object created yet)
5. Once all the Tomes exist, the TomeCollection
object is created from them
6. Newly created TomeCollection is sent to renderer
to replace the currently used one
7. Tiles that are no longer necessary destroy their
Tome object and unstream the precooked data
buffers. Previous TomeCollection object is destroyed.
UMBRA 3 IN REDengine 3
OCCLUSION DATA STREAMING
UMBRA 3 IN REDengine 3
OCCLUSION DATA STREAMING
UMBRA 3 IN REDengine 3
DEBUG TOOLS
• Quite a few in-engine tools
• Detachable camera
• Streaming visualizations
• Memory statistics
• Geometry statistics
• All visualizations that Umbra library gives us
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENES
SAMPLE SCENE
• 43 Tomes loaded
• 61 MB of Tome data loaded
• Additional 15 MB of inter-Tome
data generated on the fly
• Over 62000 static mesh chunks
on
scene
• Less than 500 visible (~0.76%)
• Query time: ~1.8 ms
• Dynamic objects occlusion:
• Particles
• Skinned meshes
• Simulated meshes
• Decals
DEBUG OVERLAY / STATISTICS
STATISTICS
STATISTICS
• Skellige
• Area size: 8km x 8km
• Amount of geometry: 45000-50000 chunks loaded
• Average amount of visible geometry: ~1-5%
• City of Novigrad
• Area size: 8.5km x 8.5km
• Amount of geometry: over 100k chunks loaded
• Average amount of visible geometry: ~2-5%
STATISTICS
• Size of Umbra data (cooked data + object IDs)
• Skellige: ~300 MB
• Novigrad: ~250 MB
• Size of data loaded during runtime
• Skellige: 40-80 MB
• Novigrad: 45-80 MB
COOKER / DATA GENERATION
COOKER / DATA GENERATION
• Offline process
• Data built more than once per day
• Dedicated machines (server farm)
COOKER / DATA GENERATION
• Ability to build data in the editor
COOKER / DATA GENERATION
Chunks – parts of the same mesh
COOKER / DATA GENERATION
• LOD levels
• Each has drawing distance
• Set up by artists
Data Generation:
• Gather mesh
• Gather LOD level
• Gather chunks
• Assign LOD distances
• Assign unique ID
COOKER / DATA GENERATION
Retrieving data during runtime:
• Query Umbra for IDs
• Find chunk
• Push chunk for drawing
• Only visible ones
• Proper LOD level
GAME FEATURES
GAME FEATURES
WE ARE HIRING!
Play your role in CD Projekt RED:
• An international team of talented developers and avid gamers.
• Creating complex, non-linear AAA RPGs.
• Developers of the award-winning Witcher franchise, with over 5million copies
sold.
• Currently working on The Witcher 3: Wild Hunt and Cyberpunk 2077.
APPLY NOW: www.cdpred.com
Thank you for attending.
For more on Umbra 3, go to umbra3.com
Follow us on Twitter
@jbushnaief, @cz0per, @umbrasoftware
WE ARE HIRING!

More Related Content

What's hot

HDR Theory and practicce (JP)
HDR Theory and practicce (JP)HDR Theory and practicce (JP)
HDR Theory and practicce (JP)Hajime Uchimura
 
Visual Studio를 이용한 어셈블리어 학습 part 1
Visual Studio를 이용한 어셈블리어 학습 part 1Visual Studio를 이용한 어셈블리어 학습 part 1
Visual Studio를 이용한 어셈블리어 학습 part 1YEONG-CHEON YOU
 
A Bizarre Way to do Real-Time Lighting
A Bizarre Way to do Real-Time LightingA Bizarre Way to do Real-Time Lighting
A Bizarre Way to do Real-Time LightingSteven Tovey
 
LOD and Culling Systems That Scale - Unite LA
LOD and Culling Systems That Scale  - Unite LALOD and Culling Systems That Scale  - Unite LA
LOD and Culling Systems That Scale - Unite LAUnity Technologies
 
Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...
Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...
Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...Takahiro Harada
 
Secrets of CryENGINE 3 Graphics Technology
Secrets of CryENGINE 3 Graphics TechnologySecrets of CryENGINE 3 Graphics Technology
Secrets of CryENGINE 3 Graphics TechnologyTiago Sousa
 
Speed up your asset imports for big projects - Unite Copenhagen 2019
Speed up your asset imports for big projects - Unite Copenhagen 2019Speed up your asset imports for big projects - Unite Copenhagen 2019
Speed up your asset imports for big projects - Unite Copenhagen 2019Unity Technologies
 
Customize renderpipeline
Customize renderpipelineCustomize renderpipeline
Customize renderpipelineAkilarLiao
 
Moving Frostbite to Physically Based Rendering
Moving Frostbite to Physically Based RenderingMoving Frostbite to Physically Based Rendering
Moving Frostbite to Physically Based RenderingElectronic Arts / DICE
 
Optimizing the Graphics Pipeline with Compute, GDC 2016
Optimizing the Graphics Pipeline with Compute, GDC 2016Optimizing the Graphics Pipeline with Compute, GDC 2016
Optimizing the Graphics Pipeline with Compute, GDC 2016Graham Wihlidal
 
[Kgc2012] deferred forward 이창희
[Kgc2012] deferred forward 이창희[Kgc2012] deferred forward 이창희
[Kgc2012] deferred forward 이창희changehee lee
 
ビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそう
ビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそうビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそう
ビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそうUnity Technologies Japan K.K.
 
The Real-time Volumetric Cloudscapes of Horizon Zero Dawn
The Real-time Volumetric Cloudscapes of Horizon Zero DawnThe Real-time Volumetric Cloudscapes of Horizon Zero Dawn
The Real-time Volumetric Cloudscapes of Horizon Zero DawnGuerrilla
 
Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)
Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)
Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)Takahiro Harada
 
【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019
【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019
【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019UnityTechnologiesJapan002
 
Practical SPU Programming in God of War III
Practical SPU Programming in God of War IIIPractical SPU Programming in God of War III
Practical SPU Programming in God of War IIISlide_N
 

What's hot (20)

Light prepass
Light prepassLight prepass
Light prepass
 
HDR Theory and practicce (JP)
HDR Theory and practicce (JP)HDR Theory and practicce (JP)
HDR Theory and practicce (JP)
 
Practical usage of Lightmass in Architectural Visualization (Kenichi Makaya...
Practical usage of Lightmass in  Architectural Visualization  (Kenichi Makaya...Practical usage of Lightmass in  Architectural Visualization  (Kenichi Makaya...
Practical usage of Lightmass in Architectural Visualization (Kenichi Makaya...
 
Visual Studio를 이용한 어셈블리어 학습 part 1
Visual Studio를 이용한 어셈블리어 학습 part 1Visual Studio를 이용한 어셈블리어 학습 part 1
Visual Studio를 이용한 어셈블리어 학습 part 1
 
A Bizarre Way to do Real-Time Lighting
A Bizarre Way to do Real-Time LightingA Bizarre Way to do Real-Time Lighting
A Bizarre Way to do Real-Time Lighting
 
LOD and Culling Systems That Scale - Unite LA
LOD and Culling Systems That Scale  - Unite LALOD and Culling Systems That Scale  - Unite LA
LOD and Culling Systems That Scale - Unite LA
 
Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...
Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...
Introduction to Bidirectional Path Tracing (BDPT) & Implementation using Open...
 
Secrets of CryENGINE 3 Graphics Technology
Secrets of CryENGINE 3 Graphics TechnologySecrets of CryENGINE 3 Graphics Technology
Secrets of CryENGINE 3 Graphics Technology
 
DirectX 11 Rendering in Battlefield 3
DirectX 11 Rendering in Battlefield 3DirectX 11 Rendering in Battlefield 3
DirectX 11 Rendering in Battlefield 3
 
Masked Occlusion Culling
Masked Occlusion CullingMasked Occlusion Culling
Masked Occlusion Culling
 
Speed up your asset imports for big projects - Unite Copenhagen 2019
Speed up your asset imports for big projects - Unite Copenhagen 2019Speed up your asset imports for big projects - Unite Copenhagen 2019
Speed up your asset imports for big projects - Unite Copenhagen 2019
 
Customize renderpipeline
Customize renderpipelineCustomize renderpipeline
Customize renderpipeline
 
Moving Frostbite to Physically Based Rendering
Moving Frostbite to Physically Based RenderingMoving Frostbite to Physically Based Rendering
Moving Frostbite to Physically Based Rendering
 
Optimizing the Graphics Pipeline with Compute, GDC 2016
Optimizing the Graphics Pipeline with Compute, GDC 2016Optimizing the Graphics Pipeline with Compute, GDC 2016
Optimizing the Graphics Pipeline with Compute, GDC 2016
 
[Kgc2012] deferred forward 이창희
[Kgc2012] deferred forward 이창희[Kgc2012] deferred forward 이창희
[Kgc2012] deferred forward 이창희
 
ビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそう
ビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそうビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそう
ビジュアルスクリプティングで始めるUnity入門1日目 プレイヤーを動かそう
 
The Real-time Volumetric Cloudscapes of Horizon Zero Dawn
The Real-time Volumetric Cloudscapes of Horizon Zero DawnThe Real-time Volumetric Cloudscapes of Horizon Zero Dawn
The Real-time Volumetric Cloudscapes of Horizon Zero Dawn
 
Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)
Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)
Introduction to Monte Carlo Ray Tracing, OpenCL Implementation (CEDEC 2014)
 
【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019
【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019
【Unite Tokyo 2019】Unityプログレッシブライトマッパー2019
 
Practical SPU Programming in God of War III
Practical SPU Programming in God of War IIIPractical SPU Programming in God of War III
Practical SPU Programming in God of War III
 

Similar to Solving Visibility and Streaming in the The Witcher 3: Wild Hunt with Umbra 3

Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3
Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3
Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3jasinb
 
Hands-on with Umbra in Unity - Past, Present and the Future
Hands-on with Umbra in Unity - Past, Present and the FutureHands-on with Umbra in Unity - Past, Present and the Future
Hands-on with Umbra in Unity - Past, Present and the FutureSampo Lappalainen
 
Gpu with cuda architecture
Gpu with cuda architectureGpu with cuda architecture
Gpu with cuda architectureDhaval Kaneria
 
Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...
Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...
Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...Unity Technologies
 
Analysis of KinectFusion
Analysis of KinectFusionAnalysis of KinectFusion
Analysis of KinectFusionDong-Won Shin
 
Write retrogames in the web and add something more with Azure
Write retrogames in the web and add something more with AzureWrite retrogames in the web and add something more with Azure
Write retrogames in the web and add something more with AzureMarco Parenzan
 
How to Make Norikra Perfect
How to Make Norikra PerfectHow to Make Norikra Perfect
How to Make Norikra PerfectSATOSHI TAGOMORI
 
Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...
Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...
Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...Aritra Sarkar
 
La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...
La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...
La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...Sardegna Ricerche
 
Optimal Strategies for Large-Scale Batch ETL Jobs
Optimal Strategies for Large-Scale Batch ETL JobsOptimal Strategies for Large-Scale Batch ETL Jobs
Optimal Strategies for Large-Scale Batch ETL JobsEmma Tang
 
Optimal Strategies for Large Scale Batch ETL Jobs with Emma Tang
Optimal Strategies for Large Scale Batch ETL Jobs with Emma TangOptimal Strategies for Large Scale Batch ETL Jobs with Emma Tang
Optimal Strategies for Large Scale Batch ETL Jobs with Emma TangDatabricks
 
Developing Next-Generation Games with Stage3D (Molehill)
Developing Next-Generation Games with Stage3D (Molehill) Developing Next-Generation Games with Stage3D (Molehill)
Developing Next-Generation Games with Stage3D (Molehill) Jean-Philippe Doiron
 
OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...
OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...
OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...NETWAYS
 
Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...
Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...
Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...Daosheng Mu
 
Ai expo 2019
Ai expo 2019Ai expo 2019
Ai expo 2019Ben Weber
 
Visug: Say Hello to my little friend: a session on Kinect
Visug: Say Hello to my little friend: a session on KinectVisug: Say Hello to my little friend: a session on Kinect
Visug: Say Hello to my little friend: a session on KinectVisug
 
Using Riak for Events storage and analysis at Booking.com
Using Riak for Events storage and analysis at Booking.comUsing Riak for Events storage and analysis at Booking.com
Using Riak for Events storage and analysis at Booking.comDamien Krotkine
 

Similar to Solving Visibility and Streaming in the The Witcher 3: Wild Hunt with Umbra 3 (20)

Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3
Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3
Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3
 
Hands-on with Umbra in Unity - Past, Present and the Future
Hands-on with Umbra in Unity - Past, Present and the FutureHands-on with Umbra in Unity - Past, Present and the Future
Hands-on with Umbra in Unity - Past, Present and the Future
 
DigitalCreationLita
DigitalCreationLitaDigitalCreationLita
DigitalCreationLita
 
Gpu with cuda architecture
Gpu with cuda architectureGpu with cuda architecture
Gpu with cuda architecture
 
Collecting 600M events/day
Collecting 600M events/dayCollecting 600M events/day
Collecting 600M events/day
 
Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...
Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...
Developing and optimizing a procedural game: The Elder Scrolls Blades- Unite ...
 
Analysis of KinectFusion
Analysis of KinectFusionAnalysis of KinectFusion
Analysis of KinectFusion
 
Write retrogames in the web and add something more with Azure
Write retrogames in the web and add something more with AzureWrite retrogames in the web and add something more with Azure
Write retrogames in the web and add something more with Azure
 
How to Make Norikra Perfect
How to Make Norikra PerfectHow to Make Norikra Perfect
How to Make Norikra Perfect
 
Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...
Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...
Elevation mapping using stereo vision enabled heterogeneous multi-agent robot...
 
La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...
La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...
La piattaforma Ruju per la ricostruzione 3D di scene e oggetti reali a partir...
 
Optimal Strategies for Large-Scale Batch ETL Jobs
Optimal Strategies for Large-Scale Batch ETL JobsOptimal Strategies for Large-Scale Batch ETL Jobs
Optimal Strategies for Large-Scale Batch ETL Jobs
 
Optimal Strategies for Large Scale Batch ETL Jobs with Emma Tang
Optimal Strategies for Large Scale Batch ETL Jobs with Emma TangOptimal Strategies for Large Scale Batch ETL Jobs with Emma Tang
Optimal Strategies for Large Scale Batch ETL Jobs with Emma Tang
 
Developing Next-Generation Games with Stage3D (Molehill)
Developing Next-Generation Games with Stage3D (Molehill) Developing Next-Generation Games with Stage3D (Molehill)
Developing Next-Generation Games with Stage3D (Molehill)
 
OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...
OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...
OSMC 2009 | Implementing a large monitoring infrastructure with Nagios and Ga...
 
Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...
Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...
Using The New Flash Stage3D Web Technology To Build Your Own Next 3D Browser ...
 
Ai expo 2019
Ai expo 2019Ai expo 2019
Ai expo 2019
 
Visug: Say Hello to my little friend: a session on Kinect
Visug: Say Hello to my little friend: a session on KinectVisug: Say Hello to my little friend: a session on Kinect
Visug: Say Hello to my little friend: a session on Kinect
 
Using Riak for Events storage and analysis at Booking.com
Using Riak for Events storage and analysis at Booking.comUsing Riak for Events storage and analysis at Booking.com
Using Riak for Events storage and analysis at Booking.com
 
Android performance
Android performanceAndroid performance
Android performance
 

Recently uploaded

TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providermohitmore19
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...MyIntelliSource, Inc.
 
Hand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxHand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxbodapatigopi8531
 
Professional Resume Template for Software Developers
Professional Resume Template for Software DevelopersProfessional Resume Template for Software Developers
Professional Resume Template for Software DevelopersVinodh Ram
 
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...ICS
 
DNT_Corporate presentation know about us
DNT_Corporate presentation know about usDNT_Corporate presentation know about us
DNT_Corporate presentation know about usDynamic Netsoft
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfkalichargn70th171
 
Adobe Marketo Engage Deep Dives: Using Webhooks to Transfer Data
Adobe Marketo Engage Deep Dives: Using Webhooks to Transfer DataAdobe Marketo Engage Deep Dives: Using Webhooks to Transfer Data
Adobe Marketo Engage Deep Dives: Using Webhooks to Transfer DataBradBedford3
 
5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdfWave PLM
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVshikhaohhpro
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsJhone kinadey
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...MyIntelliSource, Inc.
 
Cloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStackCloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStackVICTOR MAESTRE RAMIREZ
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxComplianceQuest1
 
Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...OnePlan Solutions
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsAndolasoft Inc
 
Active Directory Penetration Testing, cionsystems.com.pdf
Active Directory Penetration Testing, cionsystems.com.pdfActive Directory Penetration Testing, cionsystems.com.pdf
Active Directory Penetration Testing, cionsystems.com.pdfCionsystems
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsAlberto González Trastoy
 

Recently uploaded (20)

TECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service providerTECUNIQUE: Success Stories: IT Service provider
TECUNIQUE: Success Stories: IT Service provider
 
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
Try MyIntelliAccount Cloud Accounting Software As A Service Solution Risk Fre...
 
Hand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptxHand gesture recognition PROJECT PPT.pptx
Hand gesture recognition PROJECT PPT.pptx
 
Professional Resume Template for Software Developers
Professional Resume Template for Software DevelopersProfessional Resume Template for Software Developers
Professional Resume Template for Software Developers
 
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
The Real-World Challenges of Medical Device Cybersecurity- Mitigating Vulnera...
 
DNT_Corporate presentation know about us
DNT_Corporate presentation know about usDNT_Corporate presentation know about us
DNT_Corporate presentation know about us
 
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdfLearn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
Learn the Fundamentals of XCUITest Framework_ A Beginner's Guide.pdf
 
Adobe Marketo Engage Deep Dives: Using Webhooks to Transfer Data
Adobe Marketo Engage Deep Dives: Using Webhooks to Transfer DataAdobe Marketo Engage Deep Dives: Using Webhooks to Transfer Data
Adobe Marketo Engage Deep Dives: Using Webhooks to Transfer Data
 
5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf5 Signs You Need a Fashion PLM Software.pdf
5 Signs You Need a Fashion PLM Software.pdf
 
Optimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTVOptimizing AI for immediate response in Smart CCTV
Optimizing AI for immediate response in Smart CCTV
 
Right Money Management App For Your Financial Goals
Right Money Management App For Your Financial GoalsRight Money Management App For Your Financial Goals
Right Money Management App For Your Financial Goals
 
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
Steps To Getting Up And Running Quickly With MyTimeClock Employee Scheduling ...
 
Cloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStackCloud Management Software Platforms: OpenStack
Cloud Management Software Platforms: OpenStack
 
Exploring iOS App Development: Simplifying the Process
Exploring iOS App Development: Simplifying the ProcessExploring iOS App Development: Simplifying the Process
Exploring iOS App Development: Simplifying the Process
 
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS LiveVip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
Vip Call Girls Noida ➡️ Delhi ➡️ 9999965857 No Advance 24HRS Live
 
A Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docxA Secure and Reliable Document Management System is Essential.docx
A Secure and Reliable Document Management System is Essential.docx
 
Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...Advancing Engineering with AI through the Next Generation of Strategic Projec...
Advancing Engineering with AI through the Next Generation of Strategic Projec...
 
How To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.jsHow To Use Server-Side Rendering with Nuxt.js
How To Use Server-Side Rendering with Nuxt.js
 
Active Directory Penetration Testing, cionsystems.com.pdf
Active Directory Penetration Testing, cionsystems.com.pdfActive Directory Penetration Testing, cionsystems.com.pdf
Active Directory Penetration Testing, cionsystems.com.pdf
 
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time ApplicationsUnveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
Unveiling the Tech Salsa of LAMs with Janus in Real-Time Applications
 

Solving Visibility and Streaming in the The Witcher 3: Wild Hunt with Umbra 3

  • 1. Solving Visibility and Streaming in The Witcher 3: Wild Hunt with Umbra 3 Jasin Bushnaief, Umbra Software Przemysław Czatrowski, CD Projekt RED
  • 2. Agenda INTRODUCTION UMBRA 3 OVERVIEW THE WITCHER 3 REQUIREMENTS MIDDLEWARE AND THE REDEngine 3 UMBRA 3 IN REDEngine 3
  • 3. 3 UMBRA SOFTWARE OCCLUSION CULLING MIDDLEWARE FOR 3D GAMES FOUNDED IN 2007 14 EMPLOYEES BASED IN HELSINKI, FINLAND SUPPORT OFFICE IN SEATTLE, WA “Level artists are there to fill the world with content. Integrating Umbra saved us not only artist time but the time to create and maintain an efficient visibility culling solution. Umbra’s support provides us with the solutions and features that we need.” “Umbra’s technology is playing an important role in the creation of our next universe, by freeing our artists from the burden of manual markups typically associated with polygon soup.”
  • 5.
  • 6.
  • 7.
  • 8.
  • 10.
  • 12. WHY LICENSE? + SAVE ENGINEERS’ TIME + SAVE ARTISTS’ TIME + IT’S EASY + PORTABLE + PROVEN + SUPPORT - ENGINEERS DON’T GET TO ROLL THEIR OWN 
  • 13. The Witcher 3 Requirements HOW TO SATISFY IN UMBRA 3?
  • 14.
  • 15. THE WITCHER 3 REQUIREMENTS • LARGE, OPEN WORLD →PVS, MANUAL STUFF OUT OF QUESTION • UMBRA IS AUTOMATIC • STREAMING • LODs
  • 17.
  • 21. STREAMING IN UMBRA 3 VISIBLE OBJECTS COMBINED DATA
  • 22. STREAMING CHALLENGES • INDEPENDENT BLOCKS • MATCH ON BORDERS • DO IT QUICKLY!
  • 23. LODs IN UMBRA 3 • PREVIOUSLY: SCENE CONSISTS OF SINGLE OBJECT INSTANCES • PROBLEMS: – NEED MULTIPLE LOD LEVELS – SELF-OCCLUSION BETWEEN LEVELS – LOD HIERARCHIES?
  • 24. LODs SOLVED DISTANCE RANGE LOD 0 LOD 1 LOD 2 LOD 3 Z = 0 Z = LIKE, A LOT (OCCLUDER)
  • 25. LOD CHALLENGES • DISTANCE REFERENCE POINT • OTHER CRITERIA FOR LOD SELECTION • SMARTER LOD OCCLUDERS
  • 26. SOLVING VISIBILITY in REDengine 3 with UMBRA 3 ABOUT CD PROJEKT RED • Located in Warsaw and Cracow, Poland • Established in 2002 • Focused on RPGs
  • 27. ABOUT CD PROJEKT RED • The Witcher (2007) • PC, heavily modified Aurora Engine • The Witcher 2: Assasins of Kings (2011) • PC, heavily modified Aurora Engine • The Witcher 2: Assasins of Kings Enhanced Edition (2012) • PC/X360, REDengine 2 • metacritics score: 88 SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 28. ABOUT CD PROJEKT RED • The Witcher 3: Wild Hunt • REDengine 3 • Releasing in February 2015 • PC/XBOX / PS4 • Cyberpunk 2077 • REDengine 3 • Release date TBD SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 29. THE WITCHER 3: WILD HUNT 35x bigger than The Witcher 2 • open world • complex streaming • a lot of tools refactoring • different approaches Engine team: • 16 people SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 30. AGENDA • Why middleware? • Things we consider • Umbra 3 as middleware for REDengine 3 • Integration process • Editor features • Cooker / data generation • Game features • Summary SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 31. WHY MIDDLEWARE? • Pros • Too much time to provide own solutions • Documentation • Customer support • Often access to source code • Specific solutions for specific game • Cons • Evaluation time • Pipeline modifications • Code integrations • Code not written by us SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 32. WHY MIDDLEWARE? • “Business” aspects • Documentation – quality • Customer support • Changes to our pipeline • Source / libs • Technical aspects • Changes to our pipeline • Memory management • Multithreading • Amount of data to provide • How it “fits” the engine SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 33. WHY MIDDLEWARE? • Middlewares that we use in the game • Umbra 3 • PhysX • APEX • SpeedTree • Wwise • Scaleform SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 34. UMBRA 3 AS A MIDDLEWARE FOR REDengine 3 • Documentation • Escription of the classes, methods and concepts behind solutions • basic tutorials • Access to source code / libraries • Both • Customer support • Great • Really short response time • Precise answers and solution suggestions • Changes in our pipeline • From the artists’ point of view - none SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 35. UMBRA 3 AS A MIDDLEWARE FOR REDengine 3 • Memory management • Ability to plug in your own allocator • Multithreading • Multithreaded building and querues • Amount of data to provide • Triangle soup • No additional data created by artists • Additional work • Coming up with ID scheme • Including occlusion culling in the renderingpart • Tools for building occlusion data SOLVING VISIBILITY in REDengine 3 with UMBRA 3
  • 36. Editor features UMBRA 3 IN REDengine 3
  • 37. UMBRA 3 IN REDengine 3 OCCLUSION DATA STREAMING
  • 38. UMBRA 3 IN REDengine 3 OCCLUSION DATA STREAMING 1. From certain camera position required set of Tiles is determined 2. If the newly determined set differs from the currently used one, asynchronous computation starts 3. Precooked buffers are streamed in (only for Tiles, that had no data streamed in yet) 4. Tome objects are created (only for Tiles that haven’t had this object created yet) 5. Once all the Tomes exist, the TomeCollection object is created from them 6. Newly created TomeCollection is sent to renderer to replace the currently used one 7. Tiles that are no longer necessary destroy their Tome object and unstream the precooked data buffers. Previous TomeCollection object is destroyed.
  • 39. UMBRA 3 IN REDengine 3 OCCLUSION DATA STREAMING
  • 40. UMBRA 3 IN REDengine 3 OCCLUSION DATA STREAMING
  • 41. UMBRA 3 IN REDengine 3
  • 42. DEBUG TOOLS • Quite a few in-engine tools • Detachable camera • Streaming visualizations • Memory statistics • Geometry statistics • All visualizations that Umbra library gives us
  • 51. SAMPLE SCENE • 43 Tomes loaded • 61 MB of Tome data loaded • Additional 15 MB of inter-Tome data generated on the fly • Over 62000 static mesh chunks on scene • Less than 500 visible (~0.76%) • Query time: ~1.8 ms • Dynamic objects occlusion: • Particles • Skinned meshes • Simulated meshes • Decals
  • 52. DEBUG OVERLAY / STATISTICS
  • 54. STATISTICS • Skellige • Area size: 8km x 8km • Amount of geometry: 45000-50000 chunks loaded • Average amount of visible geometry: ~1-5% • City of Novigrad • Area size: 8.5km x 8.5km • Amount of geometry: over 100k chunks loaded • Average amount of visible geometry: ~2-5%
  • 55. STATISTICS • Size of Umbra data (cooked data + object IDs) • Skellige: ~300 MB • Novigrad: ~250 MB • Size of data loaded during runtime • Skellige: 40-80 MB • Novigrad: 45-80 MB
  • 56. COOKER / DATA GENERATION
  • 57. COOKER / DATA GENERATION • Offline process • Data built more than once per day • Dedicated machines (server farm)
  • 58. COOKER / DATA GENERATION • Ability to build data in the editor
  • 59. COOKER / DATA GENERATION Chunks – parts of the same mesh
  • 60. COOKER / DATA GENERATION • LOD levels • Each has drawing distance • Set up by artists Data Generation: • Gather mesh • Gather LOD level • Gather chunks • Assign LOD distances • Assign unique ID
  • 61. COOKER / DATA GENERATION Retrieving data during runtime: • Query Umbra for IDs • Find chunk • Push chunk for drawing • Only visible ones • Proper LOD level
  • 64. WE ARE HIRING! Play your role in CD Projekt RED: • An international team of talented developers and avid gamers. • Creating complex, non-linear AAA RPGs. • Developers of the award-winning Witcher franchise, with over 5million copies sold. • Currently working on The Witcher 3: Wild Hunt and Cyberpunk 2077. APPLY NOW: www.cdpred.com
  • 65. Thank you for attending. For more on Umbra 3, go to umbra3.com Follow us on Twitter @jbushnaief, @cz0per, @umbrasoftware WE ARE HIRING!