BASIC WEDGING (nothing fancy here. Might do something more detailed later)
For when you want to vary the parameters in something and render them all out.
Eg. Caching out a sphere with different scales
In that nice boring case, you need a couple of things in your ROP area.
1.
A Geometry ROP, point the SOP path to your sphere's output
Set the Output file to something like
$HIP/geo/sphere_`$WEDGENUM`_whatever.bgeo
2.
A Wedge node
Point the Output Driver to the Geometry ROP. This shouldn't be necessary, as you can just wire the Geo ROP into the Wedge, but when using plugins such as Deadline, sometimes it doesn't know to take that input....
Let's not do random samples, so untick that.
Add a Wedge Parameter by pressing the + button, give it a name...in our case, we'll call it Radius
Type in the path for the channel we're wedging in the Channel box
eg. /obj/geo1/sphere1/scale
Set the range of values you want. Eg. 1 to 10
Set the number of steps to take - Houdini will do uniform divisions, so in our case we should get scales of 1-10 if we type 10 steps.
3.
Hit Render Wedges. Or plug your wedge rop into Deadline and submit it as normal.
NOTE -
I sometimes use a NULL in my SOP as a controller for certain things. It can be easier to wedge the channels on this null and then copy the relative values into other nodes, so everything is easily accessible.
Friday, 23 August 2019
Friday, 9 August 2019
padzero to do file names!
/tba/CLIENT_JOBS/GREY_LDN_Zalando_Dont_Change_100713/vfx/shots/sh0033/houdini/sourceimages/backplate/backplate_guide.`padzero(3,$F3-1000)`.jpg
padzero(number of zeros, thing you want to pad) turns _guide.2.jpg into _guide.002.jpg
padzero(number of zeros, thing you want to pad) turns _guide.2.jpg into _guide.002.jpg
Monday, 24 June 2019
FETCH inverting transforms at object level
Recently I transformed a camera (scaled and rotated) to make things easier to work with in Houdini.
I did this with nulls at object level, rather than within the SOP themselves.
However, when transferring my assets back to Maya there was no clear way to invert the transformation (like in the SOP level Transform nodes).
The answer to this, is to use a FETCH node (thanks Matt Evans), which I pointed toward my rotation null and I told it to invert.. This Fetch node was then plugged into the geometry I was trying to return to the original camera orientation/scale (as you would with a null).
basically!
SCALE NULL--->ROTATE NULL--->CAMERA
FETCH(points to ROTATE NULL,with invert ticked on)--->GEO
I did this with nulls at object level, rather than within the SOP themselves.
However, when transferring my assets back to Maya there was no clear way to invert the transformation (like in the SOP level Transform nodes).
The answer to this, is to use a FETCH node (thanks Matt Evans), which I pointed toward my rotation null and I told it to invert.. This Fetch node was then plugged into the geometry I was trying to return to the original camera orientation/scale (as you would with a null).
basically!
SCALE NULL--->ROTATE NULL--->CAMERA
FETCH(points to ROTATE NULL,with invert ticked on)--->GEO
Wednesday, 19 June 2019
rotate packed primitives/ WALTER ROTATE
how to rotate a/bunch of packed primitive/s -
Use a WALTER ROTATE.
in a primitive wrangle:
float randomFactor=rand(@primnum+2323)*chf("randomMult");
matrix3 rot = primintrinsic(0, "transform", @primnum);
vector4 orient = quaternion(rot);
vector x = normalize(qrotate(orient, {1,0,0}));
vector y = normalize(qrotate(orient, {0,1,0}));
rotate(rot, radians(chf("angle") * randomFactor), x);
rotate(rot, radians(chf("angley")), y);
setprimintrinsic(0, "transform", @primnum, rot);
//////////////////
Use a WALTER ROTATE.
in a primitive wrangle:
float randomFactor=rand(@primnum+2323)*chf("randomMult");
matrix3 rot = primintrinsic(0, "transform", @primnum);
vector4 orient = quaternion(rot);
vector x = normalize(qrotate(orient, {1,0,0}));
vector y = normalize(qrotate(orient, {0,1,0}));
rotate(rot, radians(chf("angle") * randomFactor), x);
rotate(rot, radians(chf("angley")), y);
setprimintrinsic(0, "transform", @primnum, rot);
//////////////////
what we are doing is:
- making a random factor to multiply the rotations, using primnum as a seed
- creating a matrix called "rot", and initialising it to the transform of the primitive
- create a vector called "orient", using the quarternion of the rot matrix
- create vectors x and y
- rotate the rot matrix using input angles for x and y
- then finally set the primitive intrinsic using the rot matrix
Labels:
intrinsic,
matrix,
orient,
primitive,
primnum,
qrotate,
quaternion,
rotate,
setprimintrinsic,
transform
Friday, 31 May 2019
vellum hair thickness
To randomise vellum hair thickness, you use pscale values. To get Vellum to recognise these values, UNTICK the Thickness box in the Vellum Constraints node.
polywire radius
To vary the thickness of your polywires, simply type in the @variable you've made into the "wire radius" field of the polywire node.. A rather simple thing that I should have figured out *facepalm*.
Tuesday, 28 May 2019
spinning particles/points/rbds
I made a previous post about spinning particles with "w" and Pop Torque.... Walter uses this & it seems much simpler (?). In your DOP network, create a Pop Spin node & in the VEXpression space type:
spinspeed = 100*(fit01(rand(@id),chf("min"),chf("max")));
axis = sample_direction_uniform(rand(@id));
Spinspeed is measured in degrees per second
Axis specifies the axis of each point you're spinning. The sample_direction_uniform() function returns a normalised vector. So here, we have a completely randomised rotation axis. Not bad.
spinspeed = 100*(fit01(rand(@id),chf("min"),chf("max")));
axis = sample_direction_uniform(rand(@id));
Spinspeed is measured in degrees per second
Axis specifies the axis of each point you're spinning. The sample_direction_uniform() function returns a normalised vector. So here, we have a completely randomised rotation axis. Not bad.
Labels:
axis,
pop spin,
pop torque,
rotation,
sample direction uniform,
spin,
spinspeed,
torque,
w
Subscribe to:
Posts (Atom)