Beach Commentary

https://www.youtube.com/watch?v=fnIv6bUGSPA

Brief Summary

As mentioned in the commentary, this scene was quite problematic throughout all of its iterations, mainly due to various rendering glitches that seemed to persist across the different machines that I had attempted to render these scenes on. The first problem as seen in the commentary track, was that my initial beach tanks whitewater simulation did not work entirely for the first half of the render, appearing to be stuck in place. This was a very difficult problem to solve as I could not find any documentation on this problem anywhere, the way I ended up partially fixing this was just creating multiple test renders until I arrived on one that worked, and even then there are still visible rendering glitches viewable in my final output.

With the time it took to render, as well as the problems that arose, this was a very frustrating experience as I didn’t have many resources available to me in terms of fixing the problem. I ended up having to move onto the other shots in my final output, following the advice of my tutors and peers I decided to leave the shot as it was.

Moving forward and looking back on this shot, obviously there are many things that I would change, aside from the render errors, I would spend more time achieving a more uniform set of waves, as well as making them slightly slower and larger, to create a bigger splash down on the beach geometry. But because of the errors involved, this is something that I will pursue in my own free time.

My beach tank renders can be viewed here.

Ocean Commentary

https://www.youtube.com/watch?v=yDtIhVaxCbw

Brief Summary

For this render, there were not too many problems encountered when it came to the actual overall quality of the scene, there was however some initial difficulty in getting the render to work on my machine. The problem was that while the in viewport simulation was easily manipulated and relatively intuitive, attempting to see the rendered view resulted in a number of errors, once again, I took to the SideFX forums to look for a fix, and as it turned out it was a relatively simple one which involved connected two pre existing nodes in the OUT menu context.

After this it was fairly smooth sailing, I spent a considerable amount of time playing around with the wave instancing parameters until i achieved a look that I liked, after which I began to render the scene, which to my surprise took an incredible amount of time at 30+ hours, this surprised me initially because there were no actual particles to be simulated within the scene, but as I later found out, most of the rendering time was due to the complex material shaders being applied to the grid.

In terms of changes I would make looking back on this shot, I would definitely spend more time on the foam and white top sections of the material builder, which I think would have elevated the realism of my ocean, as well as this, I potentially would have created a large tiled version of the ocean to show off the capabilities of the tools, but this would have increased my render times significantly.

My final render can be viewed here.

Fluid Grid Commentary

https://www.youtube.com/watch?v=r2esEmoHD0E

Brief Summary

So for my fluid grid the initial problems that arose in this shot were mainly to do with the collisions of my geometry, the grid I had created to contain the fluid was not reacting correctly with the fluid, so instead of it hitting the grid and reacting to it, the fluid simply sank straight through it. After some hunting around on various houdini forums, I found that the problem with the grid was that I was using the new version of the extrude tool, which unlike the old version did not apply thickness to the geometry, and as it turns out, when creating a collision object, without thickness they do not register correctly. The fix for this was a fairly simple one, in that I just began using the old extrude tool over the new one, which did apply some thickness to my geometry, and fixed the problem fairly quickly.

Another problem encountered with collisions was that some of my particles phased through the surface of the geometry, and began flashing in my first iterative render, again, this was a fairly simple fix in editing the grid geometry, but a costly one, since to render out the scene took upwards of 30 hours. I did however take advantage of this fact, since I had a desire to change the lighting setup of my scene as well as the material shaders on my fluid. While it was a time costly mistake to make, I much prefer the newer version of my render.

One thing I would definitely change given more time with this project, is the visible build up of fluid towards the middle point of the simulation, because I had accidentally turned down the noise in the popforce node, the force acted in a straight line, making the buildup of fluid look quite unnatural as the scene progressed. While it is a very small mistake, which most people I had showed the work to did not notice, I was not completely satisfied with the quality of the render.

My final render can be viewed here.

Pyro FX

Moving on from fluids and oceans, I decided to try my hand at Pyro FX, since this was going to be a section of my final output. Some initial teething problems arose when it came to finding learning resources for Pyro FX in Houdini, whereas previously I had mainly been utilising tutorials available on Pluralsight, I found that the Pyro tutorials available there were well beyond my current skill level within the software. The tutorial went into some depth regarding vector operators, something which I am totally unfamiliar with as well as some scripting, while I usually enjoy a challenge when it comes to learning new software skills, it became very apparent that I was out of my depth.

After discussing the issue with my tutor, we deliberated whether it would be best to utilise this learning resource while stating my ignorance on the subject or not, while he did encourage me to follow along with the video, I did not think it very useful to building my skills, since I wouldn’t actually be learning the necessary methods, but rather just copying the work. I have made a mental note of this set of tutorials however, and will be revisiting them once I feel more comfortable with Houdini.

After some hunting around the internet, I found that the most useful resource available to me regarding Pyro FX was in fact SideFXs own documentation which was available from the user guide within the software itself, after briefly reading through their own explanation of the Pyro FX tools, I began to grasp how to control them.

So when creating a flame for example, a series of nodes is created with the DOP network, much like what occurs when creating FLIP objects, the key difference being the solvers created and the parameters available within them. Unlike FLIP, attached to the Pyro solver is a resize container node, which controls the bounding box which initially surrounds the fire simulation, this is a very important node when creating Pyro and optimizing the scene. The bounding box changes dynamically depending on the size of the fire simulation, but will limit itself based on upper and lower bound parameters, for my own purposes, I found that turning off the ‘clamp to maximum bounds’ attribute suited my purposes better, so as not to cut off any part of my simulation without having to fiddle around with two seperate values. This sort of thing would definitely be more important when working with a power intensive scene, but my scenes were relatively quick to render and simulate, so turning off the clamp did not affect these times too much.

The nodes created upon using the Pyro FX tools.

The nodes created upon using the Pyro FX tools.

Also when creating a Pyro sim there are two important values when it comes to the generation of fire or smoke, these values are Fuel and Temperature, Fuel controls where the pyro sim births from, whilst temperature is the value which tells the fuel when to burn, so where fuel exists and temperature is above a certain point, burn is created. Additionally on the fuel source, much like a Flip source, noise can be added to create more turbulence from it’s origin, like Flip this creates a more photoreal, natural look when it comes to the burn.

These are my initial test renders of both fire and smoke, while the quality is not the highest, I think these show off what is possible with Pyro FX in a relatively short amount of time. I will continue to work and experiment with Pyro leading into my final output.

https://www.youtube.com/watch?v=LISEnTB3c5c

https://www.youtube.com/watch?v=68rkOeDbqrM

Evaluating these renders and gathering some feedback, the fire was of a very low resolution and it’s interaction and burn was quite uninteresting, to improve this I would most likely change the source object which the flames emit from, as well as changing the various attributes in the Pyro solver to create a more turbulent flame with more character. The smoke on the other hand, while quite satisfying to look at, and of a relatively high quality, looks quite alien, in that it appears like the smoke is in a vacuum, since there is very little dissipation. But for an initial set of test renders, both have displayed to me what is possible with Pyro FX and how I should move forward and improve my skills in this area.

Ocean FX

Moving onto the next steps of my project I wanted to experiment further with fluids, more specifically I wanted to replicate some of what I had seen of Dynamic Oceans in a few showreels. To undertake this I utilised the ‘Intro to Dynamic Oceans’ tutorial on Pluralsight. One problem I did run in to whilst making notes on this series of videos, was that once again, it was using an older version of Houdini, which had a completely different set of shelf tools for oceans, as well as a vastly different node layout when using the tools. Luckily, SideFX has a very thorough user guide, which helped me get to grips with some of the changes made in version 16. The tutorials themselves covered most, but not all of the tools available under the oceans tab, going in to a good amount of detail of the parameters which affect the simulations, as well as how to edit the materials applied when rendering. Overall, a very good set of tutorials, which enabled me to go forward and produce a good set of experiments and tests.

Aims

  • Get to grips with the ocean tools and produce test renders
  • Time my renders to enable me to plan ahead for my final output
  • Evaluate my tests and gather feedback from my peers

Prior to undertaking these experiments, I was under the impression that creating an ocean in Houdini would operate very simarlily to creating a FLIP tank, consisting of volumes and particles. However, to my surprise, when using the ocean shelf tool, no DOP network is created, this is because there are actually no dynamics to create. An ocean in Houdini is simulated by first creating a grid, the points of which are then deformed and moved at random to emulate waves.

An ocean grid as it appears in the viewport.

An ocean grid as it appears in the viewport.

The ocean spectrum node under the ocean_surface container is probably the most important node when it comes to controlling the appearance of the simulation, from here you can first control the size and resolution of the grid, the ‘Resolution Exponent’ controls how much detail is in the initial grid, the higher the value of this parameter will obviously create a much more detailed ocean surface. This parameter should also be directly tied to the number of columns and rows in the initial grid, through trial and error it was discovered that the exact value of rows and columns should be 2^ of the resolution exponent, through simply using relative references.

It’s important to note that after doing this I experienced a much slower playback in the viewport, a quick and easy way of remedying this was to use the ‘Downsampling’ parameter under the Ocean Evaluate node, at it’s default the value is a downsample of 2, basically this means that a resolution exponent value of 9 with a downsampling value of 2 will result in the viewport showing a resolution exponent of 7. Raising the downsampling will result in much faster performance in the viewport, without affecting the resolution when it comes to rendering.

Going deeper into the parameters in the ocean spectrum node, the depth value affects the uniformity of small and larger waves within the ocean, deeper oceans have a strong dispersion relationship, meaning larger, low frequency waves will move faster than smaller waves, a low value in the parameter will make both sizes of waves more uniform.

Another interesting feature here is ‘Loop Over Time’, this is essentially what it says on the tin, this can cause your ocean to loop perfectly, setting your Loop period to the length of your scene will mean that there will be no noticeable ‘cut’ between the last and first frame. This is an incredibly useful feature, in an example, if you wanted an ocean in the background of a scene, you can effectively have it loop infinitely whilst only having to actually render around 10 seconds of simulation, which would obviously save a lot of time rendering.

The speed parameter, suprisingly does not actually affect the speed of the waves, instead it controls the rise and fall of the ocean, higher values here will create larger, low frequency waves. This parameter works in tandem with another parameter ‘Scale’ which affects the size of all waves in the scene, large and small.

Directional bias affects how much individual waves will stick to the direction parameter, a high value here will make all waves more uniform in direction, so when creating my ocean I thought it a good idea to leave this value relatively low, as having completely uniform waves would most likely look quite unrealistic.

‘Chop’ affects how sharp the crest of a wave will be, and also works in tandem with the size & speed parameters, a mismatch of all of these values together can create quite a messy looking grid, as some crests will intersect into eachother.

Lastly for the ocean spectrum, is the minimum wave length, which sets the minimum size of all waves in the scene, any waves that are smaller than this value will be smoothed out of the mesh, when creating a calm, placid body of water I imagine this would be quite a useful tool, but for the purpose of a turbulent, choppy ocean, I decided to leave this value at 0.

After playing around with these values for a while, I decided to attempt to render out my ocean to get a nice proof of concept as to what to improve and change for my final output. The rendering process itself was initially quite troubling, as when I first attempted a render my ocean came out as a flat grid with no displacement map or texture. Following a tutorial didn’t really provide any help with this, since most of them were using different versions of Houdini. After some experiementing and troubleshooting I found that I had to bake out my displacement maps under the ROP output driver under the ocean_surface node. Once I had done this, I was once again surprised, it was very, very slow. To render one frame of my ocean at 1280 x 720 took 20 minutes. After some quick maths, I decided that it was probably for the best that I not attempt to a full render of 240 frames, since my best estimate on render time would be around 3 days. Further steps from this will most likely lead me to using one of the university lab computers to complete this render, as leaving my PC out of commission for that amount of time wouldn’t be very productive.

A frame of my ocean.

A frame of my ocean.

Evaluating my render, there are definitely some things I would improve. Mainly I want to further play around with the materials of the surface of the ocean and change the color ramps within, definitely increasing the blue values of the deeper sections. Secondly I would also change the displacement values of the foam and crests to make them more apparent, whilst it is a nice subtle effect currently, I really want to emulate realism in this scene, most likely I’ll try to accomplish this by using a lot of reference images to perfect the look. Overall, a decent first attempt at making an ocean, while the render times are certainly a hurdle to overcome, I believe myself to be making good progress in this area.