Jump to content
Sign in to follow this  
MoltenCrazy

Redshift Proxy Workflow in Houdini

Recommended Posts

With the help of both the Redshift community and resources here, I finally figured out the proper workflow for dealing with Redshift proxies in Houdini.

Quick summary: Out of the box, Mantra does a fantastic job automagically dealing with instanced packed primitives, carrying all the wonderful Houdini efficiencies right into the render. If you use the same workflow with Redshift, though, RS unpacks all of the primitives, consumes all your VRAM, blows out of core, devours your CPU RAM, and causes a star in nearby galaxy to supernova, annihilating several inhabited planets in the process. Okay, maybe not that last one, but you can't prove me wrong so it stays.

The trick is to use RS proxies instead of Houdini instances that are in turn driven by the Houdini instances. A lot of this was based on Michael Buckley's post. I wanted to share an annotated file with some additional tweaks to make it easier for others to get up to speed quickly with RS proxies. Trust me; it's absolutely worth it. The speed compared to Mantra is just crazy.

A few notes:

  • Keep the workflow procedural by flagging Compute Number of Points in the Points Generate SOP instead of hard-coding a number
  • Use paths that reference the Houdini $HIP and/or $JOB variables. For some reason the RS proxy calls fail if absolute paths are used
  • Do not use the SOP Instance node in Houdini; instead use the instancefile attribute in a wrangle. This was confusing as it doesn’t match the typical Houdini workflow for instancing.
  • There are a lot of posts on RS proxies that mention you always need to set the proxy geo at the world origin before caching them. That was not the case here, but I left the bypassed transform nodes in the network in case your mileage varies
  • The newest version of Redshift for Houdini has a Instance SOP Level Packed Primitives flag on the OBJ node under the Instancing tab. This is designed to basically automatically do the same thing that Mantra does. It works for some scenarios but not all; it didn't work for this simple wall fracturing example. You might want to take that option for a spin before trying this workflow.

If anyone just needs the Attribute Wrangle VEX code to copy, here it is:

 

v@pivot =  primintrinsic(1, “pivot”, @ptnum);
3@transform = primintrinsic(1, “transform”, @ptnum);
s@name = point(1, “name_orig”, @ptnum);
v@pos = point(1, “P”, @ptnum);
v@v = point(1, “v”, @ptnum);

 

Hope someone finds this useful. :)

--

mC

 

Proxy_Example_Final.hiplc

Edited by MoltenCrazy
  • Like 1
  • Thanks 1

Share this post


Link to post
Share on other sites

Redshift 2.6.28 added support for rendering Packed Primitives and instancing them.

The next Redshift release will take this a step further, and add support for Automatically Instancing SubNets as well.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this  

×