The Dop Network Object contains a dynamic simulation.
The Dop Network Object contains a DOP simulation. Simulations can consist of any number of simulation objects (which do not correspond to Objects that appear in /obj). These simulation objects are built and controlled by the DOP nodes contained in this node.
Simulation-wide controls are provided on this node, such as caching options and time step controls. The entire simulation can also be transformed using the Transform parameters of this node. Transforming a simulation at this level does not affect the simulation at all. The Transform is applied after the simulation occurs.
To improve the playback of cached fluids, increase the Cache Memory on the Simulation tab.
Clears the entire simulation cache. When viewing a DOP Network in the viewport, a button will be made active above the viewport on the right hand side. Pressing that button performs exactly the same action as pressing this Reset Simulation button.
Whether the simulation is displayed in the viewport.
The name of a file that is used as the initial state of the simulation. This file must be a simulation state file created by either a File DOP or a Dynamics Output Driver. If this parameter is set, then the DOP nodes inside this network are not processed on the first simulation timestep.
Controls the length of a simulation timestep. Usually this value will be some multiple of a frame time, but it is not required. By specifying a larger timestep the simulation will run faster but will be less accurate and less stable. Smaller timesteps give better result but calculate more slowly.
The default timestep expression will use this parameter to control how many substeps the dop simulation should perform every frame. This can be easier to adjust than working with the 1/$FPS parameter in timestep.
Specifies an offset in seconds between the simulation time
for this simulation and the global time displayed on the
playbar. If this parameter is set to 1, then this simulation
will not start cooking until frame 25. At that global time
of 1 second, the simulation time will be 0. Several
expression functions such as
The default offset time expression references this parameter to set the offset time appropriately. This allows one to set the start time in frames rather than seconds which can be more straightforward in some cases. If the start frame is set to 24, the simulation will not start cooking until frame 24. Note that if you use this, $SF and $F will no longer refer to the same thing inside the simulation.
Specifies a scale factor that relates global time to the
simulation time for this DOP Network. A value greater than
one means the simulation time advances faster than the
global time. A value less than one causes the simulation to
appear to run in slow motion relative to the global time.
Several expression functions such as
|Max Feedback Loops|
When simulation objects using different solvers are made to be mutual affectors (such as a cloth object and an RBD object), this parameter controls the maximum number of iterations to perform while attempting to resolve the two solvers. Increasing this number in situations where different solvers are mutual affectors increases the ability of the simulation to reach a satisfactory result, but can increase the simulation calculation time.
In the case of fluid simulations, since the fluid cannot adapt to the feedback forces that are applied, a value of 2 should be used rather than higher values. Higher values will just make the fluid artificially stronger and take considerable time.
|Enable Automatic Resimulation|
When any parameter inside a DOP simulation is changed, or when any referenced external node is changed, the cache of the simulation is marked as invalid. If this parameter is turned on, the next time the playbar is moved to reach a simulation time of 0, the cache will be cleared and the first simulation timestep will be recalculated. If the cache is invalidated while at a simulation time of 0, the initial state is recalculated immediately. If the current time is beyond time 0, then the most recent timestep will be recooked, and the cache beyond the current time will be cleared. But all prior timesteps will be left untouched other than to be marked invalid. If this parameter is off, the cache is marked as invalid in exactly the same way, but the cache is never cleared automatically. To recook a simulation in this mode, the Recook Simulation button on this parameter dialog or above the viewport must be used.
|Provide Data Hints|
Rules governing allowed simulation data relationships are stored in a files called dophints.cmd in the scripts directory. If this option is turned on, at the end of each timestep the simulation state is compared against the rules in that file. If any rules are broken, warnings are added to the appropriate DOP nodes. This can be very useful when learning to use DOPs or when debugging problems with a simulation. Turning this option off will improve the performance of your simulation by skipping this validation step at the end of each timestep.
|Interpolate Display Data|
If the global time is set to a value that does not line up with a simulation timestep boundary, this parameter controls how the simulation should be displayed. If this parameter is turned off, the closest simulation timestep contents are displayed. If this parameter is turned on, the contents of the previous and next simulation timesteps are interpolated to create an approximation of the simulation as it would have actually been at the current time. This option allows the simulation to appear smooth in the viewport even if the simulation timesteps do not line up with the global frame times.
Enables the simulation cache. Many solvers will not work properly unless this option is enabled. However for very large simulations, turning off this option is the best way to guarantee the smallest possible memory footprint for the simulation.
|Compress .sim Files|
Determines if .sim files written to disk for caching will be compressed. Compression can reduce the size of the disk cache significantly, but can also increase the time to cache significantly. If loading or writing to cache seems slow, try using uncompressed .sim files, especially with fluid sims.
|Allow Caching To Disk|
If the maximum size of the cache in memory is reached, the DOP Network can either delete old cache entries to make room for new entries, or old entries can be saved to disk. If this option is on, the old cache entries are saved to disk and will be reloaded from disk if needed. This mode will be slower than simply throwing away the old cache entries, but it ensures that the entire simulation history is always available regardless of the in-memory cache size.
|Cache to Disk in Non Interactive Sessions|
In non-interactive sessions, such as hscript or hython, one may often not want the entire simulation history to be available. Their default behaviour is to ignore the Allow Caching to Disk and not cache to disk. This behaviour can be overridden with this toggle. Saving old simulation states to disk can often become very expensive and, since one will not be scrubbing the playbar on the result, a waste of disk space.
|Cache Substep Data|
Some solvers perform their own internal subsampling of time to get better results. This option controls whether or not the substep data created during this internal subsampling should be kept as part of the cache, or discarded as soon as the simulation timestep has finished computing. Having this option on can be useful for debugging purposes, or if accurate display of sub-timestep data is desired. Using the actual substep data will give more accurate results that displaying interpolated data.
|Cache Memory (MB)|
Specifies how much memory in megabytes can be consumed by the cache for this simulation. Once this limit is exceeded, old cache entries are either deleted or saved to disk to make more room, depending on the value of the Allow Caching To Disk parameter value above.
|Timeless (No History)|
Each frame the simulation is started fresh as if it were the first frame. This means $SF is always 1. It also means, however, if the network consists of a File DOP with a $F based .sim file, only the current frame will have to be loaded, allowing for fast random access of baked simulations. Note that when in this mode only one frame is kept in the cache.
Normally when the Allow Caching to Disk is enabled and the simulation hits the memory limit, the simulation is saved to files in the temp directory. While these are valid .sim files, they can be hard to manage. An explicit cache disables this caching to the temporary directory. Instead, each frame is immediately cached to the specified explicit cache name. It is still kept in memory until the Cache Memory is hit, but at that point it is not saved to disk as it is already on disk. The advantage of the explicit cache is that if a cache frame already exists DOPs will not cook that frame, even if the simulation has been reset, instead it will load that frame. Further, it only needs to cook the frames after the last valid explicit cache frame before the requested frame. So if you have cache_50.sim and try to cook frame 100, cooking can start at frame 50.
The explicit cache is similar to using a File DOP in Automatic Mode. However, when you try to jump to frame 50 with a File Dop it must load the first 50 frames. With the explicit cache it can skip this step.
|Explicit Cache Files|
The file sequence to save the explicit cache to. These are .sim files, loadable with the File DOP or File SOP. The variable $SF must be used to specify the frame number - $F cannot be used because this is working in simulation space. $SF4 is also supported.
|Explicit Frames to Keep|
How much of a history to keep before the explicit cache files are deleted. A value of 0 will never delete cache files. Otherwise, frames older than this value will be erased from disk.
Note that only cache files created by this session of Houdini will be deleted. If you restart houdini with an existant cache files, they will not be deleted. This is done because you were likely restarting from a crashed location and will want to guarantee you can once again restart there if it crashes again.
|Keep Position When Parenting|
When the object is re-parented, maintain its current world position by changing the object’s transform parameters.
This menu contains options for manipulating the pre-transform values. The pre-transform is an internal transform that is applied prior to the regular transform parameters. This allows you to change the frame of reference for the translate, rotate, scale parameter values below without changing the overall transform.
The left menu chooses the order in which transforms are applied (for example, scale, then rotate, then translate). This can change the position and orientation of the object, in the same way that going a block and turning east takes you to a different place than turning east and then going a block.
The right menu chooses the order in which to rotate around the X, Y, and Z axes. Certain orders can make character joint transforms easier to use, depending on the character.
Translation along XYZ axes.
Degrees rotation about XYZ axes.
Non-uniform scaling about XYZ axes.
Local origin of the object. See also setting the pivot point .
Scale the object uniformly along all three axes.
Object to point to. Constrains an object so its
|Look At Up Vector|
When specifying a look at, it is possible to specify an up vector for the look at. This controls the roll of this object when looking at the look at object.
A reference to the curve node or object you want this object to follow.
The orientation of the object around the path.
The position of the object along the path.
If the primitive number does not exist, then it is wrapped back to the beginning. So for numbers greater than
Keyframe this value to animate the object moving along the path.
The Follow Path tool on the shelf automatically sets keyframes on this parameter that you may want to edit or replace.
The Parameterization option controls how position values between 0 and 1 correspond to knots on the path curve.
Controls how the Position parameter is translated into a point on the path curve. Use Arc-length (the default) to interpolate the position values evenly along the physical length of the curve.
Use Uniform to distribute the position values between the knots of the curve. This lets you slow down the object at certain points by bunching up knots in the path curve. However, it is much more convenient to simply edit the animation curve to control the speed of the object along the path.
|Orient Along Path|
Orient the object according to the path’s curvature.
|Orient Up Vector|
The direction vector of the object’s Y axis to orient with.
Controls automatic banking of the object as it turns corners. Set this to