Introduction
Quick start
The best way to get started quickly is to load any of the example projects in the Examples sub-folder of your TurbulenceFD installation and experiment with the settings. To create a scene from scratch, follow the following steps:
- Press Ctrl+P to open Render Properties or go the the Render Properties button on the Render tab. In there, go to the Volumetrics tab and check Use Legacy Volumetrics
- Select Add Container from the TurbulenceFD menu
- To define the shape of your emitter
- load an .lwo object
- or create geometry using Modeler, Layout's Modeler Tools/Geometry or the new Procedural Geometry tools
- or create a particle system using Items/Dynamic Obj/Particle
- With the new object selected, choose Make Emitter from the TurbulenceFD menu
- In the Channels tab of the Fluid Emitter popup, set Temperature to 1.0
- Press the Start button in the TurbulenceFD main dialog
- A dialog with a progress bar appears as the simulation is being computed.
- After simulating, you can render the result
You can jump right in with our tutorial.
Painting Fluid
One important aspect of controlling a fluid simulation (if not the most important one) is to create the right emitter setup.
You can think of the emitter as a brush used to paint a pixel image. In fact, the container works pretty much like a 3D pixel image. You paint into one or more of the fluid channels (similar to painting into the RGB and/or A channels of an image) using emitters.
The fluid simulation will then add velocities that let your "paint" flow, curl and/or expand. Essentially the result will be what you painted at the source. You'll want to try various settings for the emitter texture scale, octaves and contrast. Maybe use several small objects instead of a single big one, use particles, animate the intensity of the emission, etc.
You can start by using only the temperature channel (disable the others) and see what different effects you can get just by varying the emission pattern and animation. You may not even need more than one channel for an effect - even in a high-quality production.
Fire simulation
Fire can be simulated in several ways. All you need is one or two fields as a basis to set up your fire shader, which is what you will most likely spend the most time with. You can even use the most straightforward density simulation and turn it into a nice flame by only using good shading parameters. The density-based flame example project shows how this works. See the next section for more details on shading fire.
There are several ways to get more control over your fire simulation. They are based on the Fuel channel. Objects can emit fuel that will burn if the temperature at a voxel is above the Ignition Temperature. When fuel burns, the air heats up and expands, as specified by the Expansion parameter. This is the essential control for explosions and large fireballs. Another effect of burning fuel is the Heat Creation and Density Creation. These parameters control how much is added to the temperature and density channels per unit of burnt fuel. Heat Creation is how a fire keeps itself burning, that is keeps the temperature above the ignition temperature after the initial ignition.
Fuel may move slower than the rest of the fluid. This gives you some additional control over the shape of the flames. So does the Fuel Diffusion parameter, which will essentially blur the fuel field, letting fuel spread slowly in all directions regardless of the movement in the fluid.
The Fire channel provides an alternative channel to render fire. Fire values are large wherever fuel burns and diminish the farther away from the burning fuel they are. This creates a field that allows you to shade the flame based on the distance to the flame core. The next section will go into more detail on shading fire.
Shading fire
From a visual perspective, fire is essentially hot gas and soot particles that emit light. Most flames consist mostly of soot which is Carbon. Carbon is what is called a Black Body. A Black Body absorbs all light that hits it, hence it is black. However, when its temperature rises to over about 600 Kelvin, it starts to emit light in a very characteristic way. This is where the familiar red/orange/yellow/white colors come from. Because fire mostly consists of soot particles, this is what dominates the color of flames.
Since soot particles emit the light of a flame, that means that the more soot particles there are, the brighter the flame will be. On the other hand, since Black Bodies also absorb light, more soot particles also make the flame more opaque. These two effects are exactly what is controlled by the Opacity group of the Fire Shader. This is what you use to control the shape of the flame.
To control the color you have two options. One is to specify a color gradient directly and the other is to use the physical model that describes the colors of a radiating Black Body. The latter will give you an easy way to obtain realistic colors, while the former gives you full artistic freedom. When using the custom gradient, take care that you use a high dynamic range of colors (also make sure that the Clamp checkbox is not checked). Look at the intensity values of the default color gradient as an example. It actually has a constant orange color. Only the intensity runs from 0% to 2000%.
As mentioned above, you can shade fire using several different simulation channels. The density-based flame example uses the temperature field to drive the color and the density channel for the opacity. While the fuel-based flame shows pretty much the same using the Fuel and Fire channels. The Fuel channel gives you more freedom to simulate a reaction, but it behaves the same when it comes to shading. In these examples, the mapping of the Opacity group creates the typical flame shape. A rising plume of fuel will only burn at the outer contour where there is enough oxygen. That means that most light is also emitted only from these areas. The mapping function curve exploits the property of Density and Fire fields with large values inside the plume/flame and smaller values outside. By creating a peak in the mapping you specify where the surface of the flame should be that emits most of the light. See the F-Curve editor for more details on how you can design mapping curves.
You can also use the Fire channel to drive the color, the opacity or both. You can even shade flames without using an opacity channel at all - note that in this case, you won't have alpha information to composite your flame later on. You can still composite such a flame by using the brightness of the flame as a matte channel - remember that the brighter the flame is, the more soot particles there are and the more opaque the flame will be.
Fluid Emitter tabs
- Mode - Specifies if the object emits at all and whether the object's children emit.
- Disabled -Do not emit anything. This can be useful when testing various combinations of emitters.
- Single Object - Emit only from the object itself, not from its children.
- Include Children- Emit from the object and its children.
- Radius- If Fill Object is not checked, the emitter will affect voxels in a region around the surface of the tagged object(s). If the radius is smaller than the voxel size of the fluid container, aliasing artefacts may occur. This can result in the emission to have gaps or disappear entirely. TurbulenceFD does not anti-alias the emission in order to make the simulation and shading results more robust against changes in voxel size.
- Collision Object - If checked, the object will act as an obstacle to the flow. The fluid will have to flow around it. A moving collision object pushes the fluid around. There is a special requirement for the geometry to work as an obstacle. To sample the object geometry on the voxel grid, the simulation has to determine whether a voxel is inside the object and or outside of it. A simple plane does not work for that reason - it doesn't have an "inside". Instead, you would have to create a wall using a scaled box. All parts of the object have to be large enough to cover at least one voxel. Structures thinner than the voxel size will not be resolved properly on the voxel grid.
- Fill Object - If checked, the tagged object(s) will be filled with the values specified in this tag. Otherwise, the values will be set only in a region around the surface of the object(s). There is a special requirement for the geometry to work as a filled emitter. To sample the object geometry on the voxel grid, the simulation has to determine whether a voxel is inside the object and or outside of it. A simple plane does not work for that reason - it doesn't have an "inside". Instead, you would have to create a wall using a scaled box. All parts of the object have to be large enough to cover at least one voxel. Structures thinner than the voxel size will not be resolved properly on the voxel grid.
- Particle Property - When using particles as emitters, you can modulate the emission intensity by any of the particle properties like Age, Mass, etc. This is highly dependent on PFX Emitter "Output size" and other settings as they feed this property.
- Particle Randomization - Adds noise to the particle property before mapping it to an emission intensity using the f-curve below. Some properties may be initialized too uniformly across all particles. You can use this parameter to break up the uniformity.
- Intensity - The F-curve allows you to customize the emission intensity based on the value of the particle property chosen from the drop-down box above.
- Surface Texture - Use a texture on this parameter to control intensity of the emission across the surface of the emitter. This will control the emission within the band around the surface. For filling the inside of the emitter, only the procedural texture parameters below are used.
- Volume Texture Scale - The scale of the 4D noise texture that is applied to the emitter. The thumbnail on the left shows a preview of the noise as you change the settings.
- Volume Texture Octaves - The number of noise octaves for the texture. Each additional octave adds another, smaller scale of noise, while keeping the larger scales.
- Volume Texture Contrast - The lower the contrast value is, the more the noise texture will fade to a constant gray. A high contrast value makes the texture intensities vary less smooth.
- Volume Texture Speed - The noise texture is animated over time. You can see the animation in the preview thumbnail as you move through the timeline. This value specifies how fast the texture is animated.
- Velocity Scale - Provides a method of changing the scale of the velocity of fluid emission. This setting works in conjunction with the Container> Simulation>Velocity Tab.
- Velocity Weight - When using particles as emitters, the particles can drag the fluid along their trajectory as they move. The larger this value, the more the particles will affect the fluid velocity.
Note that vice versa, you can also let the fluid drag along the particles by using the Particle Velocity Scale parameter (see Velocity). - Normal Force - The force that the object exerts on the fluid in the direction of its surface normal. Normal Force requires more simulation time than the Direction Force below. It should be preferred for planar emitters that have the same normal everywhere like a plane or disc.
- Direction Force X, Y, Z - Emit a force that points into the direction specified here. While the Normal Force may change its direction across the emitter's surface, the Directional Force is not affected by the emitter's surface Normals.
- Pressure - Pressure can make the fluid expand or contract as it would in an explosion or black hole. Positive values cause expansion and negative values cause contraction.
There are two ways how channel values (temperature, density, fuel, burn) are added to the fluid.
- Add - the object will emit the value set in this field, per second.
- Set - the channel values for the object will be held constant the value set in this field.
To understand the difference, think about temperature. Using Set mode, you specify the temperature the object has. Using Add mode, you specify by how much the object will heat up the fluid every second. In the later case, if the fluid wouldn't carry away the heat around the object (e.g. Buoyancy is 0), it will continue to heat up the fluid infinitely. While in Set mode the value stays constant.
Temp./Dens./Fuel/Burn
The value emitted per second (in Add mode) or to be set constant at the object (in Set mode). Each of these can be animated using envelopes.