120 views
# Computer Graphics - "Unknown Waters" ## The Scene <!--![The Final Render of the Scene](https://sonic.joejoetv.de/uploads/ac02967d-8cdb-425d-8a6f-53540117b95b.png)--> ![The Final Render of the Scene with depth of field using thin lens](https://sonic.joejoetv.de/uploads/2eef1e9f-3b9a-4bcc-9f88-36fa6eb62012.png) **Scene name:** Unknown Waters **Participants:** - Lukas Auer - Johannes Schöneberger **Team name:** Donphan <div style="text-align: justify"> The scene shows a hybrid water and space ship heading through a portal to a <i>seemingly</i> familiar looking world through a giant portal while being surrounded by planets with weird auras and shapes. The style of the ship being a composition of the clashing styles of a science fiction esque space ship parts and a classic pirate ship further enhance the sense of journeying into the unknown. </div> ## Implemented Features ### Area Lights With Area Lights | With Emission Object :-------------------------:|:-------------------------: ![Bunny with Area Light](https://sonic.joejoetv.de/uploads/b2a24e68-ebdf-4390-ba61-37b2def30e02.jpg) | ![Bunny with emission](https://sonic.joejoetv.de/uploads/4960bb41-8a9c-4d04-88d3-a9057b1483d2.jpg) #### What is it? Next event estimation is a very powerful tool to more reliably find light sources in a scene. Area Lights allow light sources other than point lights to be used for next event estimation. This can be used to create less noisy images and lead to more indirect light, especially if the light source is small. #### Challenges Area Lights require some changes in the next event estimation. This on its own is not very challenging since Lightwave already helps quite a lot to add area lights, such that we only needed to do two things. 1) Sample the surface of a shape 2) Adjust the intensity of the light according to the size of the shape We achieved 1. by adding the function `SampleArea` to shapes, we wanted to use as Area Lights. Challenge 2. was a bit more tricky since we needed to figure out the surface area of the shapes, which changes with their scale. With a sphere, we solved this for example by using the cross product of the tangent and bitangent to scale the area. #### Usage in the scene We used area Lights to simulate some lights that originate outside of the scene. The fractal planet for example is illuminated from the top with an area light and the asteroids are also illuminated with area lights. ### SDFs and Ray Marching ![Fractal SDF rendered with space background](https://sonic.joejoetv.de/uploads/ced82ace-68a4-488a-8f21-274f1bae7bf7.jpg) #### What is it? SDFs can be used to represent objects using a function that returns the distance to the surface of the object at any given point in space. They are used for example in font rendering. An SDF can be rendered by using Ray Marching, which uses the SDF of an object to march forward in space by the distance to the object until the distance is small enough to consider it a hit on the object. Since SDFs are just functions that compute the distance, they can be used to render complex mathematical shapes like fractals, as seen in the image above, and smooth combinations of primitive objects. #### Challenges The basic ray marching algorithm is rather simple to implement, but to get it to interact correctly with the existing ray tracing framework took some work. Since hit positions are approximations when ray-marching SDFs, the hit points has to be moved away from the surface, in order to reduce the chance of self-intersections when casting multiple rays. Another problem was how to represent SDFs in the scene. For this, we added a new object type to the XML scene configuration in the form of primitive SDFs like Spheres, Boxes and the Mandelbulb fractal in addition to operations that combine, inflate/round and transform SDF objects contained as child nodes. For computing the normal vectors of each hit point, one needs to compute the gradient of the distance estimator function of the SDF object. Our first implementation executed the distance estimator multiple times with a small offset in each coordinate direction to compute the gradient numerically. After that, we used a library that can be used to compute the gradient function directly to get accurate normal vectors. UV mapping is also different with SDFs in comparison to using e.g. triangles in ray tracing, as one has to use different techniques to map the hit point on the SDF object to a UV coordinate. In our renderer we implemented only the Sphere mapping approach, that converts the hit point to sphere coordinates and only uses the two angles as coordinates. #### Usage in the scene SDFs are used in our scene to show an alien planet with a mandelbulb shape, which looks really intriguing with the texture we applied. *[SDF]: Signed Distance Function *[SDFs]: Signed Distance Functions ### Volumetric Rendering ![Volumetric fog](https://sonic.joejoetv.de/uploads/d319a339-8cfc-45fe-8660-f521f518e512.jpg) #### What is it? Volumes are used to simulate particles that interact with light via absorption, scattering and emission. They can be used to model smoke, clouds and many other things. We only implemented homogeneous volumes, which can already be used for very nice effects. In the render above you can see a volumetric shadow that is created by the pink homogeneous fog. #### Challenges Implementing volumes posed many challenges to us. First of all, we had to figure out how to add these volumes to the scene which proved itself to be a big challenge. In the end, we added a medium to the instance class which describes the medium that is inside the shape. At an intersection, we check if we enter or leave the shape and update the medium of the ray accordingly. The next challenge was how to model the interactions with a medium. We decided that our integrator should always keep track of the medium in which a ray starts in. Then we intersect it with the scene. We also sample the medium for a distance at which we want to interact with it. If the intersection occurs after the sampled distance for a medium interaction, we interact with the medium by simulating scattering, absorption and emissions. #### Usage in the scene In our scene, the atmosphere of the planet in the foreground is created with a medium. The medium creates very nice light effects where the surface is bright which almost looks like a flair. Also, the rings of the fractal planet are mediums, which have emissions this time. Furthermore, the engine fire of the ship is created with a volume combined with a bsdf. ### Portals #### What is it? ![An "endless hole" effect using the portals feature](https://sonic.joejoetv.de/uploads/b372e2da-1354-4556-bf8e-908465d1c70d.jpeg) A popular method for travelling in science fiction is teleportation using portals, that links two places together like one is looking through a window to the other end. We though this would be a nice addition to our already science fiction and space travel inspired scene. With portals, one can put some content in another part of the scene, but directly show it in the camera view using the mentioned window effect. If a ray hits an instance marked as a portal and the UV of the hit lies on the portal shape mask, the ray will be re-emitted from the other, linked portal with the same relative position and location, thus making it look like the ray went right through. The portals also work in a nested fashion creating a sort of "endless hole" effect as can be seen in the example image above. #### Challenges The concept of a portal in ray-tracing is relatively simple, in that each ray just gets redirected, but the big challenge was integrating it into the existing ray-tracing framework and linking both portals in a way that the transformation of each portal can be known. We solved this by using a separate object for each pair of portals called a portal link that both portal instances register themselves to and which calculates the new rays. Next Event estimation is not included in the current implementation of the feature, as it requires more work to work properly. #### Usage in the scene This feature was used in the scene to take a look at a different world that a space ship will journey to. ### Shading Normals | Without Shading Normals | With Shading Normals | |:-----------------------:|:--------------------:| |![Brick wall without shading normals](https://sonic.joejoetv.de/uploads/d64aac8d-ea4d-47e7-9d72-4120171e7302.jpeg)|![Brick wall with shading normals](https://sonic.joejoetv.de/uploads/8c0650f6-ee1a-4828-b9e2-395438dd0ec6.jpeg)| #### What is it? Modelling an object while keeping all the extremely fine details, like scratches, bumps, etc. consumes extremely many polygons, so many models come with a normal map. This maps how the normal vectors on the surface should look to approximate the finer details on the surface. In our opinion, this is a must have feature, as it enhances the look of model surfaces a lot. The implementation uses the values stored in the texture as local normal vectors pointing away from the surface and transforms them from shading space to world space instead of the real surface normal. #### Challenges As we are working with blender for creating scenes more easily, this implmentation should ideally be relatively close to how blender does it. This, however, is not that easy, as blender does many more complex things, so some trial and error had to be done to get relatively close. The first approaches tried extracting rotation from the normal vector from the map and applying that to the existing normal vector in world space, but in the end, the simplest approach was to apply the matrix transpose to the desired normal vector and recompute the tangent and bitangent vector afterwards. #### Usage in the scene Nearly every material used on the models in the scene use some normal map to improve the look of their surfaces. ### Thinlens Camera Perspective camera | Thinlense camera with high apature radius :-------------------------:|:-------------------------: ![Perspective camera](https://sonic.joejoetv.de/uploads/2e9d117f-6ff4-4b44-a50b-79b5f701a697.jpg)| ![Thinlense camera with high apature](https://sonic.joejoetv.de/uploads/0b6a8ade-d98d-488d-a9c3-43d90280d8b1.jpg) Thinlense camera with smaller apature radius | Thinlense camera with higher focal distance :-------------------------:|:-------------------------: ![Thinlense camera with smaller apature](https://sonic.joejoetv.de/uploads/92574a2a-c337-40b8-bc78-325d3e40a7d8.jpg)| ![Thinlense camera with higher focal distance](https://sonic.joejoetv.de/uploads/e9d912f5-ef25-4c72-928e-83d4215da50b.jpg) #### What is it? The thinlense camera is an alternative camera that more realistically models actual cameras. The perspective camera assumes the focal point to be infinitely small while a thinlense camera has a "focal circle". This leads to having only objects at a certain depth be sharp, and the further away objects are from this "focal plane", the more blurry they become. The thinlense camera model has two parameters: 1) The adpature radius, desribes how large the scatter area for the ray origin is 2) The focal distance, descibes at what distance the image is sharp Their influence can also be seen in the renders above. #### Challenges Figuring out how the math behind the thinlens camera model works to create the right samples was not that easy. The [Pbrt book](https://pbr-book.org/) helped us a lot here. #### Usage in the scene We used a thinlense in our scene to better show depth. It gives a feeling of the distance in space even if the asteroids in the background just become a bit blurry. ### Image Denoising Albedo | Normals :-------------------------:|:-------------------------: ![Albedo](https://sonic.joejoetv.de/uploads/7597b3a2-e5c9-4671-90b0-bfa04b80d731.jpg) | ![Normals](https://sonic.joejoetv.de/uploads/4ee748e4-98b7-4055-bd9b-582f94c748a7.jpg) Noise Output | Denoised Output :-------------------------:|:-------------------------: ![Noise Image](https://sonic.joejoetv.de/uploads/e710cec2-17e5-449b-981b-8b08a7bac411.jpg) | ![Denoised Image](https://sonic.joejoetv.de/uploads/6a5a3214-1215-4944-8869-80d00fe61033.jpg) #### What is it? [Open Image Denoise](https://www.openimagedenoise.org/) is an open-source library by Intel to denoise the output of a ray tracer. It requires an albedo image, a normal image and the output of the ray tracer to create high-quality denoising results. You can see the result of the Open Image Denoise library in the example above. #### Challenges As with any library, it needs a bit of reading to understand the provided functions and how to use them. After a bit of testing, the implementation of this feature was very straightforward. #### Usage in the scene In our render the denoising is used to significantly reduce the required number of samples per pixel. This speeds up our renderer and creates a smooth final image. ## Used Resources - [Milky Way With Stars from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/b86a6f55-3ba3-44e5-bb3c-57fbc96594e1/) - [Kloofendal 48d Partly Cloudy (Pure Sky) from Poly Haven](https://polyhaven.com/a/kloofendal_48d_partly_cloudy_puresky) - [Beach from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/ea1497e6-4081-4f38-baec-f188d246baa3/) - [Grass from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/9cfd5432-18dc-4592-a1e5-2c645a692dbc/) - [Anthurium Botany 01 from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/c2639b56-b702-410e-be38-d917f1540cb4/) - [Dead Tree Trunk from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/640b088b-634a-4fba-af1f-819e7cbf88a4/) - [Hosta Plantaginea from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/2e11cf3c-b848-4bfd-bd87-3fd9e15fc2c7/) - [Palm Tree from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/b549671d-9836-4f62-a269-1a3a85902247/) - [Random Plant from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/5469dbc4-b18e-4ddc-9d2c-1cc2d6e2789d/) - [Random Plant from BlenderKit (Yes, it's the same name)](https://www.blenderkit.com/asset-gallery-detail/8e014b2b-df90-4dcf-85e7-16c95b417394/) - [Random Plant from BlenderKit (Yes, it's again the same name)](https://www.blenderkit.com/asset-gallery-detail/7f97be9f-acd7-40ca-b430-9ba4635b3351/) - [Simple Fern from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/07baa601-52c9-4a2f-b27f-0ef061eb155b/) - [Spirea Japanica from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/365688a9-730e-4a88-8bb3-bf99d24360f6/) - [Low Poly Plants from Sketchfab](https://sketchfab.com/3d-models/low-poly-plants-adc7c77172e74cf7bbef1498e126be31) - [Wheatley core - from portal 2 (original) from Sketchfab](https://sketchfab.com/3d-models/wheatley-core-from-portal-2-original-c1bdc8523a8849bd81d6aa901daa409f) - [Alien - Day 21 - 3December from Sketchfab](https://sketchfab.com/3d-models/alien-day-21-3december-5c56d200bb354aa4be8e4d2aa0a0fed0) - [Energy FX Green Ball Of Lightning Texture Overlay from Textures4Photoshop](https://www.textures4photoshop.com/tex/bokeh-and-light/energy-fx-green-ball-of-lightning-texture-overlay.aspx) - [Venus Surface Texture from Solar System Scope](https://www.solarsystemscope.com/textures/) - [Dutch Ship Large 01 from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/84cc7529-86e7-4c96-8047-d575b852d4b6/) - [Heavy Space Cruise Ship 2 from BLenderKit](https://www.blenderkit.com/asset-gallery-detail/20eb8a2b-d6ba-4555-9a2a-1d8e2eacec28/) - [Jet Engine from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/25c26b39-f3ac-4242-85a1-c31159c5a2c2/) - [Texture 61 from DeviantArt](https://www.deviantart.com/xnienke/art/Texture-61-341511048) - [Alien Skin Texture from Pixels](https://pixels.com/featured/21-alien-skin-miroslav-nemecek.html) - [Moon from BlenderKit](https://www.blenderkit.com/asset-gallery-detail/4a6967ec-6251-4e4b-9d01-20725561c09a/) - [Asteroid model from Blenderkit 1](https://www.blenderkit.com/get-blenderkit/3fc24216-2f3a-446c-9034-bc22c48ebc3f/) - [Asteroid model from Blenderkit 2](https://www.blenderkit.com/get-blenderkit/bd61be78-096d-4d7d-840f-08161256fd52/) - [Asteroid model from Blenderkit 3](https://www.blenderkit.com/get-blenderkit/3ca3d69c-d9d5-4c87-91b9-231dba11f131/) - [Asteroid model from Blenderkit 4](https://www.blenderkit.com/get-blenderkit/3f26c03e-324e-4a0a-84c8-4729eb070222/) ## Further Comments > [color=cyan] Can the university provide computers next time? xD [Hi Mum <3](https://tools.darvin.de/info?url_short=https://unisaar.de) Here is a bonus render of our team spirit pokemon: ![Donphan having a drink](https://sonic.joejoetv.de/uploads/7ab3571b-c92b-44a4-9072-75b59964c2e4.png =400x400)