Pop Wind
Visit the Node Bible
Pop Wind
The POP Wind node applies wind to particles by updating their targetv and airresist attributes.
Main Parameters:
Activation:
-- This turns the node on/off
Group/Group Type:
-- This correlates with DOP streams and any imported groups from sops. Read up on the Group SOP node bible entry if you're not familiar with groups yet.
Guide:
-- Provides a visualization of the force being applied. This does not apply to the noise tab.
Ignore Mass:
-- Should the particle's mass affect how much the force affects it? If so, turn this off. Adding mass makes it more difficult to control, but also provides interesting variety to the simulation.
Wind Velocity:
-- This will update the @targetv attribute to this value. Think of this parameter as the velocity value that the particles are trying to be at. In practice, it's often a good idea to drive this using CHOPs to add variety to the wind direction.
Air Resistance:
-- This sets the @airresist attribute, and tells the particles how quickly it's going to reach the target velocity defined by @targetv.
Use Vexpressions:
-- The vexpressions here are intended to work in conjunction with the Force parameter above. This is not intended to work with the noise tab settings. Be sure to click the drop-down for examples on vexpressions you can use here, and for more information about vex, visit Vex Foundations I
Noise:
-----------------------------------------------
This section utilizes a curl noise
-----------------------------------------------
Amplitude:
-- How much force should be applied to the particles with the noise
Swirl Size:
-- How large the curls ought to be with the curl noise. For more information about how curl noises work, visit this link:
https://www.cct.lsu.edu/~fharhad/ganbatte/siggraph2007/CD2/content/papers/046-bridson.pdf. In practice, it's common to use this noise for large, gradual movement in your particles. Setting a large swirl size will help achieve this.
Swirl Scale:
-- Image this as scaling up the swirls in different directions. To visualize this better, visit this link:
https://al-ro.github.io/projects/curl/
Then, imagine these swirl patterns be stretched in 3 dimensions (x,y,z). The swirl scale lets you scale in these directions.
Pulse Length:
-- Over time, the curl noise will change direction. How quickly it changes its direction is based on the pulse length. Higher pulse length = direction changes slowly. Smaller pulse length = direction changes quickly.
---------------------------
The next few parameters deal with adding additional smaller details to the simulation via turbulence. Turbulence happens with a certain number of iterations (that's what you're adjusting with the turbulence number), and it's easy to think of the "iteration" of something as the number of times this node will repeat a calculation. In this case, the "turbulence" calculation is calculated multiple times to move the particles around with small details.
--------------------------
Roughness:
-- This is how much force the turbulence is allowed to apply to the particles with each iteration. In the world of noises, each iteration is considered an "octive," and the more technical definition for roughness would be the relative amplitude for each octive. The higher this goes, the more impact each iteration of turbulence will have.
Attenuation:
-- According to the docs, "Noise attenuation exponent" which... isn't very helpful. From my estimation, the "Noise attenuation" multiplies the resulting position by an exponent at the very end. If you set this to a value of 2, notice how everything goes in the positive x,y,z direction. That is because it's taking the final position and adding an exponent to (x,y,z). So, as an example, if the position in x calculated a value of -5 and we put this to the power of 2 (amp=2) then that's like doing -52. This would give us -5*-5 = 25. Likewise, everything will go negative if you provide fractional values.
In practice, attenuation isn't usually modified and doesn't seem to have any practical use within the node parameters from what I can tell. However, in vex, it is possible to utilize amplitude without it becoming uni-directional in either the positive or negative directions. The process is outlined here: https://www.keatonwilliamson.com/houdini/noise/about_noise
Offset
-- This allows an offset for the noise, and in practice, offers you a different seed to work with. In other words, move the offset for a randomly different version of the noise.
Use Vexpressions:
-- Here you can alter the magnitude of these noise parameters using vex. Be sure to play with the dropdown menu for examples and visit Vex Foundations I if you've never used vex before.
Bindings:
Bindings can be used to tell which nodes are allowed to work with each other. Nodes which belong to the same geometry name are allowed to work with each other.
As an example, if you set the binding on a pop source to "goobie" and leave everything else at its defaults, no other node in your dop network will want to work with the popsource because they have a different binding name. If, however, you go to your solver and change its binding to "goobie" as well - now the pop solver will work with the pop source node. Lastly, if you set a pop force's binding to "goobie", that will now allow the pop force to interact with the pop source node. NOTE: Global forces (ex: the Gravity DOP) do not feature any bindings and will work on all data within the dop network.
Evaluation Node Path:
In Houdini, you can use ch() expressions within the parameters of this node to do things. By default the path is set to "." This means to look at the current node when using the ch() expression. From the Houdini docs:
"For nodes with local expressions, this controls where ch() style expressions in VEX are evaluated with respect to. By making this ., you can ensure relative references work. It is important to promote this if you are embedding a node inside an HDA you are also exporting the local expressions."
Most of the time you don't need to worry about this.
Inputs:
This section deals with a situation which you might run into while using vexpressions. In vex, you must specify which input to access data from for most functions. This means 0 = first input 1 = second input, and so-on. In DOPs, you don't have the ability to plug into those inputs. Instead, you specify where that data comes from here in the input tab.
Take this example: Let's say that you want to access a point attribute from the geometry that's plugged into the first input of your dop network. You could say something like this:
v@myAttribute = point(0,"Cd",44)
This function can translate to - "I'm looking for a point attribute, read this data from geometry input #0 (which corresponds with input 1 in the inputs tab), I'm looking for an attribute called "Cd", and I want to read this attribute from point #44."
And then, within the Input tab, you can say that the first input argument (which is 0) corresponds to the first context geometry.
Featured links
About Mentorship Calls
To book a call, just visit https://www.cgforge.com/book-consultation
Study Plan Call
Look at the welcome email for further instructions on how to schedule a call if you are a Premium Subscriber.
Premium Member Discord
Unlike the standard discord server, the Premium Member server receives faster replies, feedback on projects outside CG Forge courses, and exclusive discounts on mentorship calls that aren't offered anywhere else.
Houdini Education License
In summary, the educational license of Houdini acts much like Houdini Indie - but at a discounted price. The main difference between Indie and Education is that this version of Houdini cannot be used for commercial projects. It's great, however, for learning and preparing a demo reel without the limitations of Houdini Apprentice.
Unlock Everything
Unlike workshops or individual courses, CG Forge offers an ecosystem of resources that help you forge your skills.
Redshift Discount
https://www.maxon.net/redshift
Aug 28th, 2024 Changelog
General Changes:
• New, simplified website design is now live!
◦ All new particle banner is featured on the home and after login pages
◦ The after-login page now features courses that are sorted by ones that you have recently watched. This makes it easier to continue watching whatever you’ve been working on without scrolling through all the courses to find what you’re looking for.
◦ There is also a new “resources” section that can be found beneath the “Browse Courses” on the after-login page. This makes it easier to bring up the Node Bible, the “Tips + Tricks,” or Weekly wrangle in a new tab
◦ “CG Forge Academy” has been replaced with a “Mentorship Calls” at the top menu (see below for more details)
◦ The resources dropdown now features “Tips + Tricks” (see below for details)
◦ Certification requirements have been slightly re-written to be easier to understand
◦ Subscriptions have been re-designed from the ground up (see below for details)
Subscription Changes:
• Subscriptions have changed to include a "Basic Subscription" and a "Premium Subscription" option. The Basic Subscription renews monthly, and the “Premium Subscription” renews every 4 months. Yearly subscriptions have been removed.
◦ These changes only affect new subscribers. Existing subscribers will not see anything change with their auto-renewal amount.
◦ 10% off a Redshift yearly subscription is now included with the Premium Subscription. (If you are currently a 4 or 12 month subscriber, then just email support@cgforge.com for this)
◦ A new “Study Plan” call has been added to the Premium Subscription. (If you are currently a 4 or 12 month subscriber, then just email support@cgforge.com for this)
◦ A Houdini education license is now available for “Premium” subscribers. (If you are currently a 4 or 12 month subscriber, then just email support@cgforge.com for this)
◦ For more information, visit the subscriptions page.
• CG Forge Academy has been redesigned to be easier to use.
◦ 45 minute calls have been removed. Existing coupons are still valid and can be used towards 90 minute sessions for the amount listed on each coupon.
◦ 8 week mentorships have been removed - Instead, you can book as many 90 minute calls as you’d like.
◦ Free onboarding calls have been removed - Instead, premium subscribers now receive a complimentary “Study Plan Call” that establishes a personalized curriculum moving forward.
◦ The “CG Forge Academy” top menu is now replaced with “Mentorship Calls” and only allows for booking 90 minute calls.
All new “Tips and Tricks” resource page:
• “Tips and Tricks” is now a resource page that holds all quick tips, Houdini update videos, and other miscellaneous videos in one place. If you’re looking for “Quicktips Season One and Two” or "Houdini 19 Updates" they have now migrated over to the “Tips and Tricks” resource section.
Discord changes:
• The CG Forge Discord channel will now be divided into two categories: “Basic Members” and “Premium Members.” The premium member channel will be invite-only to premium subscribers or those who are currently enrolled in a 4 or 12 month subscription. If you eligible to join the premium discord channel, email support@cgforge.com for an invitation.
◦ Basic Discord members will no longer receive support for projects that are outside the topic of CG Forge courses.
◦ Premium Discord members will receive support for projects outside of CG Forge content
◦ Premium members will receive discounts on mentorship calls, and basic members will not.
◦ Premium members will have their questions / posts answered before basic members
◦ Early access to courses will now be exclusively provided to premium members via the discord channel.
If you have any further questions about these changes, feel free to email support@cgforge.com
Cheers,
- Tyler