|On this page|
The Grain Source SOP generates emission particles suitable for the POP Grains particle solver.
How to generate the particles.
Fills the volume of the input with particles.
Scatters particles along the surface of the input.
Scatters particles along the edges of the input.
When in Solid Mode, this provides a hint of how to interpret the source.
If the input is a single volume primitive, the Fog or SDF method will be used depending whether the volume primitive has the SDF flag set.
The input is treated as a closed manifold surface.
The first volume of the input is treated as a fog volume. Voxels with a 1 value will have points, those with 0 will not have points.
Signed Distance Field
The first volume of the input is treated as a signed distance field. Voxels with negative values will have points, those with positive values will not.
The method used for generating points.
Creates points inside the entire bounding box of the input, then removes those outside the volume. This method is efficient for inputs that are close to axis-aligned boxes, but can be slow and memory inefficient for more sparse configurations. This method also provides backwards compatibility for files created prior to Houdini 14.5.
Creates points only in the active voxels of the input volume if they also lie inside the bounding volume. This method can handle very sparse configurations where the input objects are distributed across space and do not fit well into an axis-aligned bounding box. Because a sparse volume is required, this method creates an OpenVDB volume of the input internally.
The smallest distance between any two of the generated points in the initial configuration.
pscale refers to a radius, the resulting
pscale will be half of
this to make room for two radii between each particle.
If you halve the point separation, you get eight times the points.
Allows for over packing of the input geometry. This is useful if explicit constraints are present as it gives more collision points and reduces the ability of particles to tunnel between each other. However, it means that the particles will be packed too close together, so if breaking occurs they will gain significant energy when they detach.
The density is measured along a single axis. Thus a density of
Solid mode will generate 8 times the particles, in Sheet mode 4 times the
particles, and in Strand mode 2 times the particles.
Offsets the input surface by a multiple of pscale. Positive values dilate, negative values erode. The default of -1 erodes the volume by pscale so that particles and their radii end up inside the volume.
The offset used for building the initial dense packed grid of particles. This can be offset to ensure your initial particles are precisely aligned with a ground plane, for example.
Scattering, jittering, and randomizing the sizes of the particles use this as the seed. Changing it gives different random distributions.
If all particles have the same size, many optimizations can be performed later in the simulation. However, it may be worth the expense to break up the uniform look of the particles. This enables the particles to be non-uniform in size.
Controls the range of random particle sizes. The randomization occurs over the volume, not the radius, giving a better distribution.
Controls jittering of point positions. To avoid explosions on the first frame, it is important for the relaxation to be run if jittering is on.
Because relaxation can never accurately separate all particles, note
that the final
pscale will be reduced to minimize overlap.
If a uniform lattice of points is being built, then the surface layer will exhibit terracing as points cross the boundary. This dithers the points, comparing the distance to the cut-off threshold with a random number to see if the point should be kept. This causes points to be kept outside of the threshold, as it expands half a grid scale in both directions. Turning this on will result in a more randomized surface layer.
Often an object has one face that is free, and the other faces are constrained by collisions. If you don’t want to dither the colliding faces (as particles may be generated outside of the collision range, or holes made that will collapse) you can use this normal and the angle to specify which regions of the source are available for dithering. The geometric normal of the SDF built from the surface is used, not any normal attribute on the incoming geometry.
How many degrees away from the dither normal is eligible for dithering. Setting this value to 180 will cause all faces to be dithered.
mass attribute computed from the final particle
important if the particles are varying in size. The value is the density
measured as kg/m^3. 1000 corresponds to water.
If jittering or non-uniform sizes are chosen, the default arrangement of particles will overlap, triggering explosions. This runs a pre-pass to try to move the particles without leaving the selected volume.
In Sheet mode, this corresponds to the Scatter SOP parameter of the same name.
If overlap falls below this ratio, the relaxation can be terminated early. 0.05 corresponds to a 5% overlap.
Adjust Radius to Avoid Overlap
After relaxation is complete, there may still be overlap between particles. This will cause the particles to explode outwards on the first few frames. To avoid this, this option scales the particles down by their overlap amount to ensure they are no longer overlapping. If Uniform Radius is turned on, they are all reduced equally, otherwise each is only reduced by what is required to stop it from overlapping its neighbor. However, since this opens more space, the particles probably will settle to a smaller volume.
Adds poly lines between any particles that overlap. This can be used by the grain pop as constraints.
How strong to make the constraints. This controls the threshold at which they break if breaking is enabled. It adds a
strength primitive attribute that can be altered with other tools before or during the simulation.
How far, compared to
pscale to attach neighboring points. Because explicitly constrained points do not collide with each other, this should be at least
Always Show Points
Normal points that are part of polygons are not drawn. This means the sprite display of the spheres for the points will not be drawn when they have constraints. This sets a detail attribute that overrides this, causing all points to be drawn even if they are part of primitives or constraints.
The following examples include this node.
This example demonstrates dropping slices of bacon onto a torus. It shows how to extract a 2d object from a texture map and how to repeatedly add the same grain-sheet object to DOPs.
This example demonstrates keyframing the internal grains of a solid pighead to create an animated puppet.
This example demonstrates attracting grain simulations to points on the surface of a model.